Accepting request 213905 from home:okir:branches:network
Trying again, with some more changes added... OBS-URL: https://build.opensuse.org/request/show/213905 OBS-URL: https://build.opensuse.org/package/show/network/rpcbind?expand=0&rev=28
This commit is contained in:
parent
9fd5901665
commit
513c13ffef
@ -0,0 +1,26 @@
|
|||||||
|
From a45afd335e7e5965666ac5052a54b3981796b351 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 20 Aug 2013 11:43:13 +0200
|
||||||
|
Subject: [PATCH 01/13] Silence a warning about setgroups() being implicitly
|
||||||
|
defined
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
src/rpcbind.c | 1 +
|
||||||
|
1 file changed, 1 insertion(+)
|
||||||
|
|
||||||
|
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
||||||
|
index 83dbe93..7ed72bc 100644
|
||||||
|
--- a/src/rpcbind.c
|
||||||
|
+++ b/src/rpcbind.c
|
||||||
|
@@ -65,6 +65,7 @@
|
||||||
|
#include <syslog.h>
|
||||||
|
#include <err.h>
|
||||||
|
#include <pwd.h>
|
||||||
|
+#include <grp.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#ifdef HAVE_NSS_H
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
@ -1,731 +0,0 @@
|
|||||||
Delivered-To: cr@cristianrodriguez.net
|
|
||||||
Received: by 10.180.126.41 with SMTP id mv9cs133382wib;
|
|
||||||
Thu, 22 Dec 2011 17:05:49 -0800 (PST)
|
|
||||||
Received: by 10.213.15.203 with SMTP id l11mr2621843eba.5.1324602347791;
|
|
||||||
Thu, 22 Dec 2011 17:05:47 -0800 (PST)
|
|
||||||
Return-Path: <teg@jklm.no>
|
|
||||||
Received: from mx2.suse.de (cantor2.suse.de. [195.135.220.15])
|
|
||||||
by mx.google.com with ESMTPS id q2si6918918eef.172.2011.12.22.17.05.47
|
|
||||||
(version=TLSv1/SSLv3 cipher=OTHER);
|
|
||||||
Thu, 22 Dec 2011 17:05:47 -0800 (PST)
|
|
||||||
Received-SPF: softfail (google.com: domain of transitioning teg@jklm.no does not designate 195.135.220.15 as permitted sender) client-ip=195.135.220.15;
|
|
||||||
Authentication-Results: mx.google.com; spf=softfail (google.com: domain of transitioning teg@jklm.no does not designate 195.135.220.15 as permitted sender) smtp.mail=teg@jklm.no
|
|
||||||
Received: from mail-lpp01m010-f48.google.com (mail-lpp01m010-f48.google.com [209.85.215.48])
|
|
||||||
(using TLSv1 with cipher RC4-SHA (128/128 bits))
|
|
||||||
(No client certificate requested)
|
|
||||||
by mx2.suse.de (Postfix) with ESMTP id 3ACC28738D
|
|
||||||
for <crrodriguez@opensuse.org>; Fri, 23 Dec 2011 02:05:46 +0100 (CET)
|
|
||||||
Received: by laam7 with SMTP id m7so4957545laa.35
|
|
||||||
for <crrodriguez@opensuse.org>; Thu, 22 Dec 2011 17:05:45 -0800 (PST)
|
|
||||||
Received: by 10.152.110.6 with SMTP id hw6mr10613571lab.37.1324602344510;
|
|
||||||
Thu, 22 Dec 2011 17:05:44 -0800 (PST)
|
|
||||||
Received: from localhost.localdomain (cm-84.212.224.43.getinternet.no. [84.212.224.43])
|
|
||||||
by mx.google.com with ESMTPS id 5sm9033897lah.0.2011.12.22.17.05.42
|
|
||||||
(version=TLSv1/SSLv3 cipher=OTHER);
|
|
||||||
Thu, 22 Dec 2011 17:05:43 -0800 (PST)
|
|
||||||
From: Tom Gundersen <teg@jklm.no>
|
|
||||||
To: linux-nfs@vger.kernel.org
|
|
||||||
Cc: Tom Gundersen <teg@jklm.no>, Steve Dickson <steved@redhat.com>,
|
|
||||||
systemd-devel@lists.freedesktop.org,
|
|
||||||
=?UTF-8?q?Cristian=20Rodr=C3=ADguez?= <crrodriguez@opensuse.org>
|
|
||||||
Subject: [PATCH] rpcbind: add support for systemd socket activation
|
|
||||||
Date: Fri, 23 Dec 2011 02:05:27 +0100
|
|
||||||
Message-Id: <1324602327-1789-1-git-send-email-teg@jklm.no>
|
|
||||||
X-Mailer: git-send-email 1.7.8
|
|
||||||
In-Reply-To: <4EEFCBF0.1070407@opensuse.org>
|
|
||||||
References: <4EEFCBF0.1070407@opensuse.org>
|
|
||||||
MIME-Version: 1.0
|
|
||||||
Content-Type: text/plain; charset=UTF-8
|
|
||||||
Content-Transfer-Encoding: 8bit
|
|
||||||
|
|
||||||
Making rpcbind sockect activated will greatly simplify
|
|
||||||
its integration in systemd systems. In essence, other services
|
|
||||||
may now assume that rpcbind is always available, even during very
|
|
||||||
early boot. This means that we no longer need to worry about any
|
|
||||||
ordering dependencies.
|
|
||||||
|
|
||||||
This is based on a patch originally posted by Lennart Poettering:
|
|
||||||
<http://permalink.gmane.org/gmane.linux.nfs/33774>.
|
|
||||||
|
|
||||||
That patch was not merged due to the lack of a shared library and
|
|
||||||
as systemd was seen to be too Fedora specific.
|
|
||||||
|
|
||||||
Systemd now provides a shared library, and it is shipped by defalt in
|
|
||||||
OpenSUSE in addition to Fedora, and it is available in Debain, Gentoo,
|
|
||||||
Arch, and others.
|
|
||||||
|
|
||||||
This version of the patch has three changes from the original:
|
|
||||||
|
|
||||||
* It uses the shared library.
|
|
||||||
* It comes with unit files.
|
|
||||||
* It is rebased on top of master.
|
|
||||||
|
|
||||||
Please review the patch with "git show -b" or otherwise ignoring the
|
|
||||||
whitespace changes, or it will be extremely difficult to read.
|
|
||||||
|
|
||||||
Comments welcome.
|
|
||||||
|
|
||||||
v2: correctly enable systemd code at compile time
|
|
||||||
handle the case where not all the required sockets were supplied
|
|
||||||
listen on udp/tcp port 111 in addition to /var/run/rpcbind.sock
|
|
||||||
do not daemonize
|
|
||||||
|
|
||||||
Original-patch-by: Lennart Poettering <lennart@poettering.net>
|
|
||||||
Cc: Steve Dickson <steved@redhat.com>
|
|
||||||
Cc: systemd-devel@lists.freedesktop.org
|
|
||||||
Cc: Cristian Rodríguez <crrodriguez@opensuse.org>
|
|
||||||
Signed-off-by: Tom Gundersen <teg@jklm.no>
|
|
||||||
---
|
|
||||||
|
|
||||||
Thanks to Cristian for testing. The testcase I had been using was entirely flawed,
|
|
||||||
the code did in fact not work at all. Sorry about that!
|
|
||||||
|
|
||||||
This time around it should work :-)
|
|
||||||
|
|
||||||
Makefile.am | 15 ++
|
|
||||||
configure.in | 11 +
|
|
||||||
src/rpcbind.c | 467 +++++++++++++++++++++++++-------------------
|
|
||||||
systemd/.gitignore | 1 +
|
|
||||||
systemd/rpcbind.service.in | 9 +
|
|
||||||
systemd/rpcbind.socket | 12 ++
|
|
||||||
6 files changed, 316 insertions(+), 199 deletions(-)
|
|
||||||
create mode 100644 systemd/.gitignore
|
|
||||||
create mode 100644 systemd/rpcbind.service.in
|
|
||||||
create mode 100644 systemd/rpcbind.socket
|
|
||||||
|
|
||||||
diff --git a/Makefile.am b/Makefile.am
|
|
||||||
index 9fa608e..194b467 100644
|
|
||||||
--- a/Makefile.am
|
|
||||||
+++ b/Makefile.am
|
|
||||||
@@ -38,6 +38,21 @@ rpcbind_SOURCES = \
|
|
||||||
src/warmstart.c
|
|
||||||
rpcbind_LDADD = $(TIRPC_LIBS)
|
|
||||||
|
|
||||||
+if SYSTEMD
|
|
||||||
+AM_CPPFLAGS += $(SYSTEMD_CFLAGS) -DSYSTEMD
|
|
||||||
+
|
|
||||||
+rpcbind_LDADD += $(SYSTEMD_LIBS)
|
|
||||||
+
|
|
||||||
+systemd/rpcbind.service: systemd/rpcbind.service.in Makefile
|
|
||||||
+ sed -e 's,@bindir\@,$(bindir),g' \
|
|
||||||
+ < $< > $@ || rm $@
|
|
||||||
+
|
|
||||||
+systemdsystemunit_DATA = \
|
|
||||||
+ systemd/rpcbind.service \
|
|
||||||
+ systemd/rpcbind.socket
|
|
||||||
+
|
|
||||||
+endif
|
|
||||||
+
|
|
||||||
rpcinfo_SOURCES = src/rpcinfo.c
|
|
||||||
rpcinfo_LDADD = $(TIRPC_LIBS)
|
|
||||||
|
|
||||||
diff --git a/configure.in b/configure.in
|
|
||||||
index 2b67720..397d52d 100644
|
|
||||||
--- a/configure.in
|
|
||||||
+++ b/configure.in
|
|
||||||
@@ -29,6 +29,17 @@ AC_SUBST([rpcuser], [$with_rpcuser])
|
|
||||||
|
|
||||||
PKG_CHECK_MODULES([TIRPC], [libtirpc])
|
|
||||||
|
|
||||||
+PKG_PROG_PKG_CONFIG
|
|
||||||
+AC_ARG_WITH([systemdsystemunitdir],
|
|
||||||
+ AS_HELP_STRING([--with-systemdsystemunitdir=DIR], [Directory for systemd service files]),
|
|
||||||
+ [], [with_systemdsystemunitdir=$($PKG_CONFIG --variable=systemdsystemunitdir systemd)])
|
|
||||||
+ if test "x$with_systemdsystemunitdir" != xno; then
|
|
||||||
+ AC_SUBST([systemdsystemunitdir], [$with_systemdsystemunitdir])
|
|
||||||
+ PKG_CHECK_MODULES([SYSTEMD], [libsystemd-daemon])
|
|
||||||
+ fi
|
|
||||||
+AM_CONDITIONAL(SYSTEMD, [test -n "$with_systemdsystemunitdir" -a "x$with_systemdsystemunitdir" != xno ])
|
|
||||||
+
|
|
||||||
+
|
|
||||||
AS_IF([test x$enable_libwrap = xyes], [
|
|
||||||
AC_CHECK_LIB([wrap], [hosts_access], ,
|
|
||||||
AC_MSG_ERROR([libwrap support requested but unable to find libwrap]))
|
|
||||||
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
|
||||||
index 24e069b..a87ce05 100644
|
|
||||||
--- a/src/rpcbind.c
|
|
||||||
+++ b/src/rpcbind.c
|
|
||||||
@@ -56,6 +56,9 @@
|
|
||||||
#include <netinet/in.h>
|
|
||||||
#endif
|
|
||||||
#include <arpa/inet.h>
|
|
||||||
+#ifdef SYSTEMD
|
|
||||||
+#include <systemd/sd-daemon.h>
|
|
||||||
+#endif
|
|
||||||
#include <fcntl.h>
|
|
||||||
#include <netdb.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
@@ -281,6 +284,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
u_int32_t host_addr[4]; /* IPv4 or IPv6 */
|
|
||||||
struct sockaddr_un sun;
|
|
||||||
mode_t oldmask;
|
|
||||||
+ int n = 0;
|
|
||||||
res = NULL;
|
|
||||||
|
|
||||||
if ((nconf->nc_semantics != NC_TPI_CLTS) &&
|
|
||||||
@@ -300,141 +304,285 @@ init_transport(struct netconfig *nconf)
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
- /*
|
|
||||||
- * XXX - using RPC library internal functions. For NC_TPI_CLTS
|
|
||||||
- * we call this later, for each socket we like to bind.
|
|
||||||
- */
|
|
||||||
- if (nconf->nc_semantics != NC_TPI_CLTS) {
|
|
||||||
- if ((fd = __rpc_nconf2fd(nconf)) < 0) {
|
|
||||||
- syslog(LOG_ERR, "cannot create socket for %s",
|
|
||||||
- nconf->nc_netid);
|
|
||||||
- return (1);
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
if (!__rpc_nconf2sockinfo(nconf, &si)) {
|
|
||||||
syslog(LOG_ERR, "cannot get information for %s",
|
|
||||||
nconf->nc_netid);
|
|
||||||
return (1);
|
|
||||||
}
|
|
||||||
|
|
||||||
- if ((strcmp(nconf->nc_netid, "local") == 0) ||
|
|
||||||
- (strcmp(nconf->nc_netid, "unix") == 0)) {
|
|
||||||
- memset(&sun, 0, sizeof sun);
|
|
||||||
- sun.sun_family = AF_LOCAL;
|
|
||||||
- unlink(_PATH_RPCBINDSOCK);
|
|
||||||
- strcpy(sun.sun_path, _PATH_RPCBINDSOCK);
|
|
||||||
- addrlen = SUN_LEN(&sun);
|
|
||||||
- sa = (struct sockaddr *)&sun;
|
|
||||||
- } else {
|
|
||||||
- /* Get rpcbind's address on this transport */
|
|
||||||
-
|
|
||||||
- memset(&hints, 0, sizeof hints);
|
|
||||||
- hints.ai_flags = AI_PASSIVE;
|
|
||||||
- hints.ai_family = si.si_af;
|
|
||||||
- hints.ai_socktype = si.si_socktype;
|
|
||||||
- hints.ai_protocol = si.si_proto;
|
|
||||||
+#ifdef SYSTEMD
|
|
||||||
+ n = sd_listen_fds(0);
|
|
||||||
+ if (n < 0) {
|
|
||||||
+ syslog(LOG_ERR, "failed to acquire systemd scokets: %s", strerror(-n));
|
|
||||||
+ return 1;
|
|
||||||
}
|
|
||||||
- if (nconf->nc_semantics == NC_TPI_CLTS) {
|
|
||||||
- /*
|
|
||||||
- * If no hosts were specified, just bind to INADDR_ANY. Otherwise
|
|
||||||
- * make sure 127.0.0.1 is added to the list.
|
|
||||||
- */
|
|
||||||
- nhostsbak = nhosts;
|
|
||||||
- nhostsbak++;
|
|
||||||
- hosts = realloc(hosts, nhostsbak * sizeof(char *));
|
|
||||||
- if (nhostsbak == 1)
|
|
||||||
- hosts[0] = "*";
|
|
||||||
- else {
|
|
||||||
- if (hints.ai_family == AF_INET) {
|
|
||||||
- hosts[nhostsbak - 1] = "127.0.0.1";
|
|
||||||
- } else if (hints.ai_family == AF_INET6) {
|
|
||||||
- hosts[nhostsbak - 1] = "::1";
|
|
||||||
- } else
|
|
||||||
- return 1;
|
|
||||||
+
|
|
||||||
+ /* Try to find if one of the systemd sockets we were given match
|
|
||||||
+ * our netconfig structure. */
|
|
||||||
+
|
|
||||||
+ for (fd = SD_LISTEN_FDS_START; fd < SD_LISTEN_FDS_START + n; fd++) {
|
|
||||||
+ struct __rpc_sockinfo si_other;
|
|
||||||
+ union {
|
|
||||||
+ struct sockaddr sa;
|
|
||||||
+ struct sockaddr_un un;
|
|
||||||
+ struct sockaddr_in in4;
|
|
||||||
+ struct sockaddr_in6 in6;
|
|
||||||
+ struct sockaddr_storage storage;
|
|
||||||
+ } sa;
|
|
||||||
+ socklen_t addrlen = sizeof(sa);
|
|
||||||
+
|
|
||||||
+ if (!__rpc_fd2sockinfo(fd, &si_other)) {
|
|
||||||
+ syslog(LOG_ERR, "cannot get information for fd %i", fd);
|
|
||||||
+ return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
- /*
|
|
||||||
- * Bind to specific IPs if asked to
|
|
||||||
- */
|
|
||||||
- checkbind = 0;
|
|
||||||
- while (nhostsbak > 0) {
|
|
||||||
- --nhostsbak;
|
|
||||||
- /*
|
|
||||||
- * XXX - using RPC library internal functions.
|
|
||||||
- */
|
|
||||||
+ if (si.si_af != si_other.si_af ||
|
|
||||||
+ si.si_socktype != si_other.si_socktype ||
|
|
||||||
+ si.si_proto != si_other.si_proto)
|
|
||||||
+ continue;
|
|
||||||
+
|
|
||||||
+ if (getsockname(fd, &sa.sa, &addrlen) < 0) {
|
|
||||||
+ syslog(LOG_ERR, "failed to query socket name: %s",
|
|
||||||
+ strerror(errno));
|
|
||||||
+ goto error;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ /* Copy the address */
|
|
||||||
+ taddr.addr.maxlen = taddr.addr.len = addrlen;
|
|
||||||
+ taddr.addr.buf = malloc(addrlen);
|
|
||||||
+ if (taddr.addr.buf == NULL) {
|
|
||||||
+ syslog(LOG_ERR,
|
|
||||||
+ "cannot allocate memory for %s address",
|
|
||||||
+ nconf->nc_netid);
|
|
||||||
+ goto error;
|
|
||||||
+ }
|
|
||||||
+ memcpy(taddr.addr.buf, &sa, addrlen);
|
|
||||||
+
|
|
||||||
+ my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr,
|
|
||||||
+ RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
|
||||||
+ if (my_xprt == (SVCXPRT *)NULL) {
|
|
||||||
+ syslog(LOG_ERR, "%s: could not create service",
|
|
||||||
+ nconf->nc_netid);
|
|
||||||
+ goto error;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ /* if none of the systemd sockets matched, we set up the socket in
|
|
||||||
+ * the normal way:
|
|
||||||
+ */
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
+ if(my_xprt == (SVCXPRT *)NULL) {
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * XXX - using RPC library internal functions. For NC_TPI_CLTS
|
|
||||||
+ * we call this later, for each socket we like to bind.
|
|
||||||
+ */
|
|
||||||
+ if (nconf->nc_semantics != NC_TPI_CLTS) {
|
|
||||||
if ((fd = __rpc_nconf2fd(nconf)) < 0) {
|
|
||||||
syslog(LOG_ERR, "cannot create socket for %s",
|
|
||||||
nconf->nc_netid);
|
|
||||||
return (1);
|
|
||||||
}
|
|
||||||
- switch (hints.ai_family) {
|
|
||||||
- case AF_INET:
|
|
||||||
- if (inet_pton(AF_INET, hosts[nhostsbak],
|
|
||||||
- host_addr) == 1) {
|
|
||||||
- hints.ai_flags &= AI_NUMERICHOST;
|
|
||||||
- } else {
|
|
||||||
- /*
|
|
||||||
- * Skip if we have an AF_INET6 adress.
|
|
||||||
- */
|
|
||||||
- if (inet_pton(AF_INET6,
|
|
||||||
- hosts[nhostsbak], host_addr) == 1)
|
|
||||||
- continue;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if ((strcmp(nconf->nc_netid, "local") == 0) ||
|
|
||||||
+ (strcmp(nconf->nc_netid, "unix") == 0)) {
|
|
||||||
+ memset(&sun, 0, sizeof sun);
|
|
||||||
+ sun.sun_family = AF_LOCAL;
|
|
||||||
+ unlink(_PATH_RPCBINDSOCK);
|
|
||||||
+ strcpy(sun.sun_path, _PATH_RPCBINDSOCK);
|
|
||||||
+ addrlen = SUN_LEN(&sun);
|
|
||||||
+ sa = (struct sockaddr *)&sun;
|
|
||||||
+ } else {
|
|
||||||
+ /* Get rpcbind's address on this transport */
|
|
||||||
+
|
|
||||||
+ memset(&hints, 0, sizeof hints);
|
|
||||||
+ hints.ai_flags = AI_PASSIVE;
|
|
||||||
+ hints.ai_family = si.si_af;
|
|
||||||
+ hints.ai_socktype = si.si_socktype;
|
|
||||||
+ hints.ai_protocol = si.si_proto;
|
|
||||||
+ }
|
|
||||||
+ if (nconf->nc_semantics == NC_TPI_CLTS) {
|
|
||||||
+ /*
|
|
||||||
+ * If no hosts were specified, just bind to INADDR_ANY. Otherwise
|
|
||||||
+ * make sure 127.0.0.1 is added to the list.
|
|
||||||
+ */
|
|
||||||
+ nhostsbak = nhosts;
|
|
||||||
+ nhostsbak++;
|
|
||||||
+ hosts = realloc(hosts, nhostsbak * sizeof(char *));
|
|
||||||
+ if (nhostsbak == 1)
|
|
||||||
+ hosts[0] = "*";
|
|
||||||
+ else {
|
|
||||||
+ if (hints.ai_family == AF_INET) {
|
|
||||||
+ hosts[nhostsbak - 1] = "127.0.0.1";
|
|
||||||
+ } else if (hints.ai_family == AF_INET6) {
|
|
||||||
+ hosts[nhostsbak - 1] = "::1";
|
|
||||||
+ } else
|
|
||||||
+ return 1;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * Bind to specific IPs if asked to
|
|
||||||
+ */
|
|
||||||
+ checkbind = 0;
|
|
||||||
+ while (nhostsbak > 0) {
|
|
||||||
+ --nhostsbak;
|
|
||||||
+ /*
|
|
||||||
+ * XXX - using RPC library internal functions.
|
|
||||||
+ */
|
|
||||||
+ if ((fd = __rpc_nconf2fd(nconf)) < 0) {
|
|
||||||
+ syslog(LOG_ERR, "cannot create socket for %s",
|
|
||||||
+ nconf->nc_netid);
|
|
||||||
+ return (1);
|
|
||||||
+ }
|
|
||||||
+ switch (hints.ai_family) {
|
|
||||||
+ case AF_INET:
|
|
||||||
+ if (inet_pton(AF_INET, hosts[nhostsbak],
|
|
||||||
+ host_addr) == 1) {
|
|
||||||
+ hints.ai_flags &= AI_NUMERICHOST;
|
|
||||||
+ } else {
|
|
||||||
+ /*
|
|
||||||
+ * Skip if we have an AF_INET6 adress.
|
|
||||||
+ */
|
|
||||||
+ if (inet_pton(AF_INET6,
|
|
||||||
+ hosts[nhostsbak], host_addr) == 1)
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
+ break;
|
|
||||||
+ case AF_INET6:
|
|
||||||
+ if (inet_pton(AF_INET6, hosts[nhostsbak],
|
|
||||||
+ host_addr) == 1) {
|
|
||||||
+ hints.ai_flags &= AI_NUMERICHOST;
|
|
||||||
+ } else {
|
|
||||||
+ /*
|
|
||||||
+ * Skip if we have an AF_INET adress.
|
|
||||||
+ */
|
|
||||||
+ if (inet_pton(AF_INET, hosts[nhostsbak],
|
|
||||||
+ host_addr) == 1)
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
+ break;
|
|
||||||
+ default:
|
|
||||||
+ break;
|
|
||||||
}
|
|
||||||
- break;
|
|
||||||
- case AF_INET6:
|
|
||||||
- if (inet_pton(AF_INET6, hosts[nhostsbak],
|
|
||||||
- host_addr) == 1) {
|
|
||||||
- hints.ai_flags &= AI_NUMERICHOST;
|
|
||||||
- } else {
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * If no hosts were specified, just bind to INADDR_ANY
|
|
||||||
+ */
|
|
||||||
+ if (strcmp("*", hosts[nhostsbak]) == 0)
|
|
||||||
+ hosts[nhostsbak] = NULL;
|
|
||||||
+
|
|
||||||
+ if ((aicode = getaddrinfo(hosts[nhostsbak],
|
|
||||||
+ servname, &hints, &res)) != 0) {
|
|
||||||
+ if ((aicode = getaddrinfo(hosts[nhostsbak],
|
|
||||||
+ "portmapper", &hints, &res)) != 0) {
|
|
||||||
+ syslog(LOG_ERR,
|
|
||||||
+ "cannot get local address for %s: %s",
|
|
||||||
+ nconf->nc_netid, gai_strerror(aicode));
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ addrlen = res->ai_addrlen;
|
|
||||||
+ sa = (struct sockaddr *)res->ai_addr;
|
|
||||||
+ oldmask = umask(S_IXUSR|S_IXGRP|S_IXOTH);
|
|
||||||
+ if (bind(fd, sa, addrlen) != 0) {
|
|
||||||
+ syslog(LOG_ERR, "cannot bind %s on %s: %m",
|
|
||||||
+ (hosts[nhostsbak] == NULL) ? "*" :
|
|
||||||
+ hosts[nhostsbak], nconf->nc_netid);
|
|
||||||
+ if (res != NULL)
|
|
||||||
+ freeaddrinfo(res);
|
|
||||||
+ continue;
|
|
||||||
+ } else
|
|
||||||
+ checkbind++;
|
|
||||||
+ (void) umask(oldmask);
|
|
||||||
+
|
|
||||||
+ /* Copy the address */
|
|
||||||
+ taddr.addr.maxlen = taddr.addr.len = addrlen;
|
|
||||||
+ taddr.addr.buf = malloc(addrlen);
|
|
||||||
+ if (taddr.addr.buf == NULL) {
|
|
||||||
+ syslog(LOG_ERR,
|
|
||||||
+ "cannot allocate memory for %s address",
|
|
||||||
+ nconf->nc_netid);
|
|
||||||
+ if (res != NULL)
|
|
||||||
+ freeaddrinfo(res);
|
|
||||||
+ return 1;
|
|
||||||
+ }
|
|
||||||
+ memcpy(taddr.addr.buf, sa, addrlen);
|
|
||||||
+#ifdef RPCBIND_DEBUG
|
|
||||||
+ if (debugging) {
|
|
||||||
/*
|
|
||||||
- * Skip if we have an AF_INET adress.
|
|
||||||
+ * for debugging print out our universal
|
|
||||||
+ * address
|
|
||||||
*/
|
|
||||||
- if (inet_pton(AF_INET, hosts[nhostsbak],
|
|
||||||
- host_addr) == 1)
|
|
||||||
- continue;
|
|
||||||
+ char *uaddr;
|
|
||||||
+ struct netbuf nb;
|
|
||||||
+ int sa_size = 0;
|
|
||||||
+
|
|
||||||
+ nb.buf = sa;
|
|
||||||
+ switch( sa->sa_family){
|
|
||||||
+ case AF_INET:
|
|
||||||
+ sa_size = sizeof (struct sockaddr_in);
|
|
||||||
+ break;
|
|
||||||
+ case AF_INET6:
|
|
||||||
+ sa_size = sizeof (struct sockaddr_in6);
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+ nb.len = nb.maxlen = sa_size;
|
|
||||||
+ uaddr = taddr2uaddr(nconf, &nb);
|
|
||||||
+ (void) fprintf(stderr,
|
|
||||||
+ "rpcbind : my address is %s\n", uaddr);
|
|
||||||
+ (void) free(uaddr);
|
|
||||||
+ }
|
|
||||||
+#endif
|
|
||||||
+ my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr,
|
|
||||||
+ RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
|
||||||
+ if (my_xprt == (SVCXPRT *)NULL) {
|
|
||||||
+ syslog(LOG_ERR, "%s: could not create service",
|
|
||||||
+ nconf->nc_netid);
|
|
||||||
+ goto error;
|
|
||||||
}
|
|
||||||
- break;
|
|
||||||
- default:
|
|
||||||
- break;
|
|
||||||
}
|
|
||||||
-
|
|
||||||
- /*
|
|
||||||
- * If no hosts were specified, just bind to INADDR_ANY
|
|
||||||
- */
|
|
||||||
- if (strcmp("*", hosts[nhostsbak]) == 0)
|
|
||||||
- hosts[nhostsbak] = NULL;
|
|
||||||
-
|
|
||||||
- if ((aicode = getaddrinfo(hosts[nhostsbak],
|
|
||||||
- servname, &hints, &res)) != 0) {
|
|
||||||
- if ((aicode = getaddrinfo(hosts[nhostsbak],
|
|
||||||
- "portmapper", &hints, &res)) != 0) {
|
|
||||||
- syslog(LOG_ERR,
|
|
||||||
- "cannot get local address for %s: %s",
|
|
||||||
- nconf->nc_netid, gai_strerror(aicode));
|
|
||||||
- continue;
|
|
||||||
- }
|
|
||||||
+ if (!checkbind)
|
|
||||||
+ return 1;
|
|
||||||
+ } else { /* NC_TPI_COTS */
|
|
||||||
+ if ((strcmp(nconf->nc_netid, "local") != 0) &&
|
|
||||||
+ (strcmp(nconf->nc_netid, "unix") != 0)) {
|
|
||||||
+ if ((aicode = getaddrinfo(NULL, servname, &hints, &res))!= 0) {
|
|
||||||
+ if ((aicode = getaddrinfo(NULL, "portmapper", &hints, &res))!= 0) {
|
|
||||||
+ printf("cannot get local address for %s: %s", nconf->nc_netid, gai_strerror(aicode));
|
|
||||||
+ syslog(LOG_ERR,
|
|
||||||
+ "cannot get local address for %s: %s",
|
|
||||||
+ nconf->nc_netid, gai_strerror(aicode));
|
|
||||||
+ return 1;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ addrlen = res->ai_addrlen;
|
|
||||||
+ sa = (struct sockaddr *)res->ai_addr;
|
|
||||||
}
|
|
||||||
- addrlen = res->ai_addrlen;
|
|
||||||
- sa = (struct sockaddr *)res->ai_addr;
|
|
||||||
oldmask = umask(S_IXUSR|S_IXGRP|S_IXOTH);
|
|
||||||
- if (bind(fd, sa, addrlen) != 0) {
|
|
||||||
- syslog(LOG_ERR, "cannot bind %s on %s: %m",
|
|
||||||
- (hosts[nhostsbak] == NULL) ? "*" :
|
|
||||||
- hosts[nhostsbak], nconf->nc_netid);
|
|
||||||
+ __rpc_fd2sockinfo(fd, &si);
|
|
||||||
+ if (setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &on,
|
|
||||||
+ sizeof(on)) != 0) {
|
|
||||||
+ syslog(LOG_ERR, "cannot set SO_REUSEADDR on %s",
|
|
||||||
+ nconf->nc_netid);
|
|
||||||
if (res != NULL)
|
|
||||||
freeaddrinfo(res);
|
|
||||||
- continue;
|
|
||||||
- } else
|
|
||||||
- checkbind++;
|
|
||||||
+ return 1;
|
|
||||||
+ }
|
|
||||||
+ if (bind(fd, sa, addrlen) < 0) {
|
|
||||||
+ syslog(LOG_ERR, "cannot bind %s: %m", nconf->nc_netid);
|
|
||||||
+ if (res != NULL)
|
|
||||||
+ freeaddrinfo(res);
|
|
||||||
+ return 1;
|
|
||||||
+ }
|
|
||||||
(void) umask(oldmask);
|
|
||||||
|
|
||||||
/* Copy the address */
|
|
||||||
- taddr.addr.maxlen = taddr.addr.len = addrlen;
|
|
||||||
+ taddr.addr.len = taddr.addr.maxlen = addrlen;
|
|
||||||
taddr.addr.buf = malloc(addrlen);
|
|
||||||
if (taddr.addr.buf == NULL) {
|
|
||||||
- syslog(LOG_ERR,
|
|
||||||
- "cannot allocate memory for %s address",
|
|
||||||
+ syslog(LOG_ERR, "cannot allocate memory for %s address",
|
|
||||||
nconf->nc_netid);
|
|
||||||
if (res != NULL)
|
|
||||||
freeaddrinfo(res);
|
|
||||||
@@ -443,116 +591,37 @@ init_transport(struct netconfig *nconf)
|
|
||||||
memcpy(taddr.addr.buf, sa, addrlen);
|
|
||||||
#ifdef RPCBIND_DEBUG
|
|
||||||
if (debugging) {
|
|
||||||
- /*
|
|
||||||
- * for debugging print out our universal
|
|
||||||
- * address
|
|
||||||
- */
|
|
||||||
+ /* for debugging print out our universal address */
|
|
||||||
char *uaddr;
|
|
||||||
struct netbuf nb;
|
|
||||||
- int sa_size = 0;
|
|
||||||
+ int sa_size2 = 0;
|
|
||||||
|
|
||||||
nb.buf = sa;
|
|
||||||
switch( sa->sa_family){
|
|
||||||
case AF_INET:
|
|
||||||
- sa_size = sizeof (struct sockaddr_in);
|
|
||||||
+ sa_size2 = sizeof (struct sockaddr_in);
|
|
||||||
break;
|
|
||||||
case AF_INET6:
|
|
||||||
- sa_size = sizeof (struct sockaddr_in6);
|
|
||||||
+ sa_size2 = sizeof (struct sockaddr_in6);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
- nb.len = nb.maxlen = sa_size;
|
|
||||||
+ nb.len = nb.maxlen = sa_size2;
|
|
||||||
uaddr = taddr2uaddr(nconf, &nb);
|
|
||||||
- (void) fprintf(stderr,
|
|
||||||
- "rpcbind : my address is %s\n", uaddr);
|
|
||||||
+ (void) fprintf(stderr, "rpcbind : my address is %s\n",
|
|
||||||
+ uaddr);
|
|
||||||
(void) free(uaddr);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
- my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr,
|
|
||||||
- RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
|
||||||
+
|
|
||||||
+ listen(fd, SOMAXCONN);
|
|
||||||
+
|
|
||||||
+ my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr, RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
|
||||||
if (my_xprt == (SVCXPRT *)NULL) {
|
|
||||||
- syslog(LOG_ERR, "%s: could not create service",
|
|
||||||
- nconf->nc_netid);
|
|
||||||
+ syslog(LOG_ERR, "%s: could not create service",
|
|
||||||
+ nconf->nc_netid);
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
- if (!checkbind)
|
|
||||||
- return 1;
|
|
||||||
- } else { /* NC_TPI_COTS */
|
|
||||||
- if ((strcmp(nconf->nc_netid, "local") != 0) &&
|
|
||||||
- (strcmp(nconf->nc_netid, "unix") != 0)) {
|
|
||||||
- if ((aicode = getaddrinfo(NULL, servname, &hints, &res))!= 0) {
|
|
||||||
- if ((aicode = getaddrinfo(NULL, "portmapper", &hints, &res))!= 0) {
|
|
||||||
- printf("cannot get local address for %s: %s", nconf->nc_netid, gai_strerror(aicode));
|
|
||||||
- syslog(LOG_ERR,
|
|
||||||
- "cannot get local address for %s: %s",
|
|
||||||
- nconf->nc_netid, gai_strerror(aicode));
|
|
||||||
- return 1;
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
- addrlen = res->ai_addrlen;
|
|
||||||
- sa = (struct sockaddr *)res->ai_addr;
|
|
||||||
- }
|
|
||||||
- oldmask = umask(S_IXUSR|S_IXGRP|S_IXOTH);
|
|
||||||
- __rpc_fd2sockinfo(fd, &si);
|
|
||||||
- if (setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &on,
|
|
||||||
- sizeof(on)) != 0) {
|
|
||||||
- syslog(LOG_ERR, "cannot set SO_REUSEADDR on %s",
|
|
||||||
- nconf->nc_netid);
|
|
||||||
- if (res != NULL)
|
|
||||||
- freeaddrinfo(res);
|
|
||||||
- return 1;
|
|
||||||
- }
|
|
||||||
- if (bind(fd, sa, addrlen) < 0) {
|
|
||||||
- syslog(LOG_ERR, "cannot bind %s: %m", nconf->nc_netid);
|
|
||||||
- if (res != NULL)
|
|
||||||
- freeaddrinfo(res);
|
|
||||||
- return 1;
|
|
||||||
- }
|
|
||||||
- (void) umask(oldmask);
|
|
||||||
-
|
|
||||||
- /* Copy the address */
|
|
||||||
- taddr.addr.len = taddr.addr.maxlen = addrlen;
|
|
||||||
- taddr.addr.buf = malloc(addrlen);
|
|
||||||
- if (taddr.addr.buf == NULL) {
|
|
||||||
- syslog(LOG_ERR, "cannot allocate memory for %s address",
|
|
||||||
- nconf->nc_netid);
|
|
||||||
- if (res != NULL)
|
|
||||||
- freeaddrinfo(res);
|
|
||||||
- return 1;
|
|
||||||
- }
|
|
||||||
- memcpy(taddr.addr.buf, sa, addrlen);
|
|
||||||
-#ifdef RPCBIND_DEBUG
|
|
||||||
- if (debugging) {
|
|
||||||
- /* for debugging print out our universal address */
|
|
||||||
- char *uaddr;
|
|
||||||
- struct netbuf nb;
|
|
||||||
- int sa_size2 = 0;
|
|
||||||
-
|
|
||||||
- nb.buf = sa;
|
|
||||||
- switch( sa->sa_family){
|
|
||||||
- case AF_INET:
|
|
||||||
- sa_size2 = sizeof (struct sockaddr_in);
|
|
||||||
- break;
|
|
||||||
- case AF_INET6:
|
|
||||||
- sa_size2 = sizeof (struct sockaddr_in6);
|
|
||||||
- break;
|
|
||||||
- }
|
|
||||||
- nb.len = nb.maxlen = sa_size2;
|
|
||||||
- uaddr = taddr2uaddr(nconf, &nb);
|
|
||||||
- (void) fprintf(stderr, "rpcbind : my address is %s\n",
|
|
||||||
- uaddr);
|
|
||||||
- (void) free(uaddr);
|
|
||||||
- }
|
|
||||||
-#endif
|
|
||||||
-
|
|
||||||
- listen(fd, SOMAXCONN);
|
|
||||||
-
|
|
||||||
- my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr, RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
|
||||||
- if (my_xprt == (SVCXPRT *)NULL) {
|
|
||||||
- syslog(LOG_ERR, "%s: could not create service",
|
|
||||||
- nconf->nc_netid);
|
|
||||||
- goto error;
|
|
||||||
- }
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef PORTMAP
|
|
||||||
diff --git a/systemd/.gitignore b/systemd/.gitignore
|
|
||||||
new file mode 100644
|
|
||||||
index 0000000..b7b4561
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/systemd/.gitignore
|
|
||||||
@@ -0,0 +1 @@
|
|
||||||
+rpcbind.service
|
|
||||||
diff --git a/systemd/rpcbind.service.in b/systemd/rpcbind.service.in
|
|
||||||
new file mode 100644
|
|
||||||
index 0000000..58ae5de
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/systemd/rpcbind.service.in
|
|
||||||
@@ -0,0 +1,9 @@
|
|
||||||
+[Unit]
|
|
||||||
+Description=RPC Bind
|
|
||||||
+
|
|
||||||
+[Service]
|
|
||||||
+ExecStart=@bindir@/rpcbind -w -f
|
|
||||||
+
|
|
||||||
+[Install]
|
|
||||||
+WantedBy=multi-user.target
|
|
||||||
+Also=rpcbind.socket
|
|
||||||
diff --git a/systemd/rpcbind.socket b/systemd/rpcbind.socket
|
|
||||||
new file mode 100644
|
|
||||||
index 0000000..ad5fd62
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/systemd/rpcbind.socket
|
|
||||||
@@ -0,0 +1,12 @@
|
|
||||||
+[Unit]
|
|
||||||
+Description=RPCbind Server Activation Socket
|
|
||||||
+Wants=rpcbind.target
|
|
||||||
+Before=rpcbind.target
|
|
||||||
+
|
|
||||||
+[Socket]
|
|
||||||
+ListenStream=/var/run/rpcbind.sock
|
|
||||||
+ListenStream=111
|
|
||||||
+ListenDatagram=111
|
|
||||||
+
|
|
||||||
+[Install]
|
|
||||||
+WantedBy=sockets.target
|
|
||||||
--
|
|
||||||
1.7.8
|
|
||||||
|
|
69
0002-Remove-obsolete-function-in6_fillscopeid.patch
Normal file
69
0002-Remove-obsolete-function-in6_fillscopeid.patch
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
From 6ec7d84694e560c7e1968b1ba02cbf69802da290 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 20 Aug 2013 11:43:51 +0200
|
||||||
|
Subject: [PATCH 02/13] Remove obsolete function in6_fillscopeid
|
||||||
|
|
||||||
|
This seems to be an old remnant from the very early days of IPv6
|
||||||
|
when the kernel would include the ifindex in the link-local
|
||||||
|
addresses returned by getifaddrs(). This is no longer the case on
|
||||||
|
Linux, so the code is a no-op.
|
||||||
|
|
||||||
|
A no-op that makes gcc throw warnings about illegal type-punning.
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
src/util.c | 24 ------------------------
|
||||||
|
1 file changed, 24 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/util.c b/src/util.c
|
||||||
|
index 9a5fb69..a6c835b 100644
|
||||||
|
--- a/src/util.c
|
||||||
|
+++ b/src/util.c
|
||||||
|
@@ -71,9 +71,6 @@ static struct sockaddr_in6 *local_in6;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static int bitmaskcmp __P((void *, void *, void *, int));
|
||||||
|
-#ifdef INET6
|
||||||
|
-static void in6_fillscopeid __P((struct sockaddr_in6 *));
|
||||||
|
-#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* For all bits set in "mask", compare the corresponding bits in
|
||||||
|
@@ -93,26 +90,6 @@ bitmaskcmp(void *dst, void *src, void *mask, int bytelen)
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
- * Similar to code in ifconfig.c. Fill in the scope ID for link-local
|
||||||
|
- * addresses returned by getifaddrs().
|
||||||
|
- */
|
||||||
|
-#ifdef INET6
|
||||||
|
-static void
|
||||||
|
-in6_fillscopeid(struct sockaddr_in6 *sin6)
|
||||||
|
-{
|
||||||
|
- u_int16_t ifindex;
|
||||||
|
-
|
||||||
|
- if (IN6_IS_ADDR_LINKLOCAL(&sin6->sin6_addr)) {
|
||||||
|
- ifindex = ntohs(*(u_int16_t *)&sin6->sin6_addr.s6_addr[2]);
|
||||||
|
- if (sin6->sin6_scope_id == 0 && ifindex != 0) {
|
||||||
|
- sin6->sin6_scope_id = ifindex;
|
||||||
|
- *(u_int16_t *)&sin6->sin6_addr.s6_addr[2] = 0;
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
-}
|
||||||
|
-#endif
|
||||||
|
-
|
||||||
|
-/*
|
||||||
|
* Find a server address that can be used by `caller' to contact
|
||||||
|
* the local service specified by `serv_uaddr'. If `clnt_uaddr' is
|
||||||
|
* non-NULL, it is used instead of `caller' as a hint suggesting
|
||||||
|
@@ -209,7 +186,6 @@ addrmerge(struct netbuf *caller, char *serv_uaddr, char *clnt_uaddr,
|
||||||
|
* a link-local address then use the scope id to see
|
||||||
|
* which one.
|
||||||
|
*/
|
||||||
|
- in6_fillscopeid(SA2SIN6(ifsa));
|
||||||
|
if (IN6_IS_ADDR_LINKLOCAL(&SA2SIN6ADDR(ifsa)) &&
|
||||||
|
IN6_IS_ADDR_LINKLOCAL(&SA2SIN6ADDR(caller_sa)) &&
|
||||||
|
IN6_IS_ADDR_LINKLOCAL(&SA2SIN6ADDR(hint_sa))) {
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
@ -0,0 +1,30 @@
|
|||||||
|
From 921c65c2f9fb023124bccd74a009a1faf1fbd476 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 20 Aug 2013 09:31:03 +0200
|
||||||
|
Subject: [PATCH 03/13] configure: fix the case when --with-rpcuser is not
|
||||||
|
given
|
||||||
|
|
||||||
|
If --with-rpcuser is not given, we would compile the code with
|
||||||
|
-DRPCBIND_USER='' which is clearly not intended
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
configure.ac | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/configure.ac b/configure.ac
|
||||||
|
index 2b67720..1cf42d3 100644
|
||||||
|
--- a/configure.ac
|
||||||
|
+++ b/configure.ac
|
||||||
|
@@ -23,7 +23,7 @@ AC_ARG_WITH([statedir],
|
||||||
|
AC_SUBST([statedir], [$with_statedir])
|
||||||
|
|
||||||
|
AC_ARG_WITH([rpcuser],
|
||||||
|
- AS_HELP_STRING([--with-rpcuser=ARG], [use ARG for RPC @<:@default=root@:>@]),
|
||||||
|
+ AS_HELP_STRING([--with-rpcuser=ARG], [use ARG for RPC @<:@default=root@:>@])
|
||||||
|
,, [with_rpcuser=root])
|
||||||
|
AC_SUBST([rpcuser], [$with_rpcuser])
|
||||||
|
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
@ -0,0 +1,50 @@
|
|||||||
|
From 77ccf636447cce013f84ee7b7b09f0fe3adcec87 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 20 Aug 2013 09:11:45 +0200
|
||||||
|
Subject: [PATCH 04/13] In init_transport, move creation of COTS sockets
|
||||||
|
closer to where they are used
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
src/rpcbind.c | 18 ++++++------------
|
||||||
|
1 file changed, 6 insertions(+), 12 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
||||||
|
index 7ed72bc..f562f7a 100644
|
||||||
|
--- a/src/rpcbind.c
|
||||||
|
+++ b/src/rpcbind.c
|
||||||
|
@@ -309,18 +309,6 @@ init_transport(struct netconfig *nconf)
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
- /*
|
||||||
|
- * XXX - using RPC library internal functions. For NC_TPI_CLTS
|
||||||
|
- * we call this later, for each socket we like to bind.
|
||||||
|
- */
|
||||||
|
- if (nconf->nc_semantics != NC_TPI_CLTS) {
|
||||||
|
- if ((fd = __rpc_nconf2fd(nconf)) < 0) {
|
||||||
|
- syslog(LOG_ERR, "cannot create socket for %s",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- return (1);
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
if (!__rpc_nconf2sockinfo(nconf, &si)) {
|
||||||
|
syslog(LOG_ERR, "cannot get information for %s",
|
||||||
|
nconf->nc_netid);
|
||||||
|
@@ -487,6 +475,12 @@ init_transport(struct netconfig *nconf)
|
||||||
|
if (!checkbind)
|
||||||
|
return 1;
|
||||||
|
} else { /* NC_TPI_COTS */
|
||||||
|
+ if ((fd = __rpc_nconf2fd(nconf)) < 0) {
|
||||||
|
+ syslog(LOG_ERR, "cannot create socket for %s",
|
||||||
|
+ nconf->nc_netid);
|
||||||
|
+ return (1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
if ((strcmp(nconf->nc_netid, "local") != 0) &&
|
||||||
|
(strcmp(nconf->nc_netid, "unix") != 0)) {
|
||||||
|
if ((aicode = getaddrinfo(NULL, servname, &hints, &res))!= 0) {
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
@ -0,0 +1,49 @@
|
|||||||
|
From 369cc50768a9929ef0adf4b58987ce08cc3675b6 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 20 Aug 2013 09:12:49 +0200
|
||||||
|
Subject: [PATCH 05/13] The use of AI_NUMERICHOST in init_transport() is
|
||||||
|
broken.
|
||||||
|
|
||||||
|
In its current form, when seeing a dotted quad or a numeric IPv6 address,
|
||||||
|
it will clear all flags in hints.ai_flags (which has been set to AI_PASSIVE
|
||||||
|
a few lines above).
|
||||||
|
|
||||||
|
What this code should really be doing is to *set* AI_NUMERICHOST if and only
|
||||||
|
if it sees a numeric address.
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
src/rpcbind.c | 6 ++++--
|
||||||
|
1 file changed, 4 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
||||||
|
index f562f7a..896d509 100644
|
||||||
|
--- a/src/rpcbind.c
|
||||||
|
+++ b/src/rpcbind.c
|
||||||
|
@@ -365,11 +365,13 @@ init_transport(struct netconfig *nconf)
|
||||||
|
nconf->nc_netid);
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ hints.ai_flags &= ~AI_NUMERICHOST;
|
||||||
|
switch (hints.ai_family) {
|
||||||
|
case AF_INET:
|
||||||
|
if (inet_pton(AF_INET, hosts[nhostsbak],
|
||||||
|
host_addr) == 1) {
|
||||||
|
- hints.ai_flags &= AI_NUMERICHOST;
|
||||||
|
+ hints.ai_flags |= AI_NUMERICHOST;
|
||||||
|
} else {
|
||||||
|
/*
|
||||||
|
* Skip if we have an AF_INET6 adress.
|
||||||
|
@@ -382,7 +384,7 @@ init_transport(struct netconfig *nconf)
|
||||||
|
case AF_INET6:
|
||||||
|
if (inet_pton(AF_INET6, hosts[nhostsbak],
|
||||||
|
host_addr) == 1) {
|
||||||
|
- hints.ai_flags &= AI_NUMERICHOST;
|
||||||
|
+ hints.ai_flags |= AI_NUMERICHOST;
|
||||||
|
} else {
|
||||||
|
/*
|
||||||
|
* Skip if we have an AF_INET adress.
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
494
0006-First-part-of-init_transport-refactoring.patch
Normal file
494
0006-First-part-of-init_transport-refactoring.patch
Normal file
@ -0,0 +1,494 @@
|
|||||||
|
From 9cea37f331fe76a9690e93677999cc47f3f70631 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 20 Aug 2013 09:26:37 +0200
|
||||||
|
Subject: [PATCH 06/13] First part of init_transport refactoring
|
||||||
|
|
||||||
|
This patch splits out the hostname resolution and socket creation/binding
|
||||||
|
code into individual functions, and calls those from init_transport instead.
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
src/rpcbind.c | 407 +++++++++++++++++++++++++++++-----------------------------
|
||||||
|
1 file changed, 201 insertions(+), 206 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
||||||
|
index 896d509..a7dcc0e 100644
|
||||||
|
--- a/src/rpcbind.c
|
||||||
|
+++ b/src/rpcbind.c
|
||||||
|
@@ -268,6 +268,186 @@ main(int argc, char *argv[])
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
+ * Helper function - maybe this should go elsewhere
|
||||||
|
+ */
|
||||||
|
+static void
|
||||||
|
+sockaddr2netbuf(const struct sockaddr *sa, socklen_t alen, struct netbuf *abuf)
|
||||||
|
+{
|
||||||
|
+ abuf->len = abuf->maxlen = alen;
|
||||||
|
+ abuf->buf = malloc(alen);
|
||||||
|
+
|
||||||
|
+ if (abuf->buf == NULL) {
|
||||||
|
+ syslog(LOG_ERR, "not enough memory for address buffer (%u bytes)", alen);
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ memcpy(abuf->buf, sa, alen);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+/*
|
||||||
|
+ * Perform hostname lookup
|
||||||
|
+ */
|
||||||
|
+static int
|
||||||
|
+do_hostname_lookup(struct netconfig *nconf, const char *hostname, struct netbuf *abuf)
|
||||||
|
+{
|
||||||
|
+ struct addrinfo hints, *res = NULL;
|
||||||
|
+ struct __rpc_sockinfo si;
|
||||||
|
+ int aicode;
|
||||||
|
+
|
||||||
|
+ if (!__rpc_nconf2sockinfo(nconf, &si)) {
|
||||||
|
+ syslog(LOG_ERR, "cannot get sockinfo for %s", nconf->nc_netid);
|
||||||
|
+ return -1;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ memset(&hints, 0, sizeof hints);
|
||||||
|
+ hints.ai_flags = AI_PASSIVE;
|
||||||
|
+ hints.ai_family = si.si_af;
|
||||||
|
+ hints.ai_socktype = si.si_socktype;
|
||||||
|
+ hints.ai_protocol = si.si_proto;
|
||||||
|
+
|
||||||
|
+ if (hostname == NULL) {
|
||||||
|
+ /*
|
||||||
|
+ * If no hosts were specified, just bind to INADDR_ANY
|
||||||
|
+ */
|
||||||
|
+ } else {
|
||||||
|
+ u_int32_t host_addr[4]; /* IPv4 or IPv6 */
|
||||||
|
+
|
||||||
|
+ switch (hints.ai_family) {
|
||||||
|
+ case AF_INET:
|
||||||
|
+ if (inet_pton(AF_INET, hostname, host_addr) == 1)
|
||||||
|
+ hints.ai_flags |= AI_NUMERICHOST;
|
||||||
|
+ else if (inet_pton(AF_INET6, hostname, host_addr) == 1)
|
||||||
|
+ return 0;
|
||||||
|
+ break;
|
||||||
|
+
|
||||||
|
+ case AF_INET6:
|
||||||
|
+ if (inet_pton(AF_INET6, hostname, host_addr) == 1)
|
||||||
|
+ hints.ai_flags |= AI_NUMERICHOST;
|
||||||
|
+ else if (inet_pton(AF_INET, hostname, host_addr) == 1)
|
||||||
|
+ return 0;
|
||||||
|
+ break;
|
||||||
|
+
|
||||||
|
+ default:
|
||||||
|
+ break;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if ((aicode = getaddrinfo(hostname, servname, &hints, &res)) != 0) {
|
||||||
|
+ if ((aicode = getaddrinfo(hostname, "portmapper", &hints, &res)) != 0) {
|
||||||
|
+ syslog(LOG_ERR,
|
||||||
|
+ "cannot get %s address for %s: %s",
|
||||||
|
+ nconf->nc_netid,
|
||||||
|
+ hostname? hostname : "*",
|
||||||
|
+ gai_strerror(aicode));
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* XXX: should we loop over all addresses returned? */
|
||||||
|
+ sockaddr2netbuf(res->ai_addr, res->ai_addrlen, abuf);
|
||||||
|
+ freeaddrinfo(res);
|
||||||
|
+ return 1;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void
|
||||||
|
+build_local_addr(const char *path, struct netbuf *abuf)
|
||||||
|
+{
|
||||||
|
+ struct sockaddr_un sun;
|
||||||
|
+
|
||||||
|
+ memset(&sun, 0, sizeof sun);
|
||||||
|
+ sun.sun_family = AF_LOCAL;
|
||||||
|
+ strcpy(sun.sun_path, path);
|
||||||
|
+
|
||||||
|
+ sockaddr2netbuf((struct sockaddr *) &sun, SUN_LEN(&sun), abuf);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+/*
|
||||||
|
+ * Create a bound socket
|
||||||
|
+ *
|
||||||
|
+ * Return values:
|
||||||
|
+ * -1 means error or problem with this netconfig entry.
|
||||||
|
+ */
|
||||||
|
+static int
|
||||||
|
+create_transport_socket(struct netconfig *nconf, const char *hostname, struct netbuf *abuf, int *fdret)
|
||||||
|
+{
|
||||||
|
+ int fd = -1;
|
||||||
|
+ int r;
|
||||||
|
+ mode_t oldmask;
|
||||||
|
+
|
||||||
|
+ *fdret = -1;
|
||||||
|
+
|
||||||
|
+ if (strcmp(nconf->nc_netid, "local") == 0 || strcmp(nconf->nc_netid, "unix") == 0) {
|
||||||
|
+ unlink(_PATH_RPCBINDSOCK);
|
||||||
|
+ build_local_addr(_PATH_RPCBINDSOCK, abuf);
|
||||||
|
+ } else {
|
||||||
|
+ r = do_hostname_lookup(nconf, hostname, abuf);
|
||||||
|
+ if (r <= 0)
|
||||||
|
+ return r;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /*
|
||||||
|
+ * XXX - using RPC library internal functions.
|
||||||
|
+ */
|
||||||
|
+ if ((fd = __rpc_nconf2fd(nconf)) < 0) {
|
||||||
|
+ syslog(LOG_ERR, "cannot create socket for %s", nconf->nc_netid);
|
||||||
|
+ return -1;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (nconf->nc_semantics != NC_TPI_CLTS) {
|
||||||
|
+ int on = 1;
|
||||||
|
+
|
||||||
|
+ /* For connection oriented sockets, always set REUSEADDR.
|
||||||
|
+ * This allows us to restart the server even if there are
|
||||||
|
+ * TCP sockets loitering around in TIME_WAIT */
|
||||||
|
+ if (setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on)) != 0) {
|
||||||
|
+ syslog(LOG_ERR, "cannot set SO_REUSEADDR on %s", nconf->nc_netid);
|
||||||
|
+ return -1;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ oldmask = umask(S_IXUSR|S_IXGRP|S_IXOTH);
|
||||||
|
+ if (bind(fd, (struct sockaddr *) abuf->buf, abuf->len) != 0) {
|
||||||
|
+ syslog(LOG_ERR, "cannot bind %s on %s: %m",
|
||||||
|
+ hostname? hostname : "*",
|
||||||
|
+ nconf->nc_netid);
|
||||||
|
+ (void) umask(oldmask);
|
||||||
|
+ goto skip;
|
||||||
|
+ }
|
||||||
|
+ (void) umask(oldmask);
|
||||||
|
+
|
||||||
|
+ if (nconf->nc_semantics != NC_TPI_CLTS) {
|
||||||
|
+ if (listen(fd, SOMAXCONN) < 0) {
|
||||||
|
+ syslog(LOG_ERR, "unable to listen on %s socket: %m",
|
||||||
|
+ nconf->nc_netid);
|
||||||
|
+ return -1;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+#ifdef RPCBIND_DEBUG
|
||||||
|
+ if (debugging) {
|
||||||
|
+ /*
|
||||||
|
+ * for debugging print out our universal
|
||||||
|
+ * address
|
||||||
|
+ */
|
||||||
|
+ char *uaddr;
|
||||||
|
+
|
||||||
|
+ uaddr = taddr2uaddr(nconf, abuf);
|
||||||
|
+ (void) fprintf(stderr, "rpcbind : my %s address is %s\n", nconf->nc_netid, uaddr);
|
||||||
|
+ (void) free(uaddr);
|
||||||
|
+ }
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
+ *fdret = fd;
|
||||||
|
+ return 1;
|
||||||
|
+
|
||||||
|
+skip:
|
||||||
|
+ if (fd >= 0)
|
||||||
|
+ close(fd);
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+/*
|
||||||
|
* Adds the entry into the rpcbind database.
|
||||||
|
* If PORTMAP, then for UDP and TCP, it adds the entries for version 2 also
|
||||||
|
* Returns 0 if succeeds, else fails
|
||||||
|
@@ -277,20 +457,9 @@ init_transport(struct netconfig *nconf)
|
||||||
|
{
|
||||||
|
int fd = -1;
|
||||||
|
struct t_bind taddr;
|
||||||
|
- struct addrinfo hints, *res;
|
||||||
|
struct __rpc_sockinfo si;
|
||||||
|
SVCXPRT *my_xprt = NULL;
|
||||||
|
int status; /* bound checking ? */
|
||||||
|
- int aicode;
|
||||||
|
- int addrlen = 0;
|
||||||
|
- int nhostsbak;
|
||||||
|
- int checkbind;
|
||||||
|
- int on = 1;
|
||||||
|
- struct sockaddr *sa = NULL;
|
||||||
|
- u_int32_t host_addr[4]; /* IPv4 or IPv6 */
|
||||||
|
- struct sockaddr_un sun;
|
||||||
|
- mode_t oldmask;
|
||||||
|
- res = NULL;
|
||||||
|
|
||||||
|
if ((nconf->nc_semantics != NC_TPI_CLTS) &&
|
||||||
|
(nconf->nc_semantics != NC_TPI_COTS) &&
|
||||||
|
@@ -315,24 +484,10 @@ init_transport(struct netconfig *nconf)
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
- if ((strcmp(nconf->nc_netid, "local") == 0) ||
|
||||||
|
- (strcmp(nconf->nc_netid, "unix") == 0)) {
|
||||||
|
- memset(&sun, 0, sizeof sun);
|
||||||
|
- sun.sun_family = AF_LOCAL;
|
||||||
|
- unlink(_PATH_RPCBINDSOCK);
|
||||||
|
- strcpy(sun.sun_path, _PATH_RPCBINDSOCK);
|
||||||
|
- addrlen = SUN_LEN(&sun);
|
||||||
|
- sa = (struct sockaddr *)&sun;
|
||||||
|
- } else {
|
||||||
|
- /* Get rpcbind's address on this transport */
|
||||||
|
-
|
||||||
|
- memset(&hints, 0, sizeof hints);
|
||||||
|
- hints.ai_flags = AI_PASSIVE;
|
||||||
|
- hints.ai_family = si.si_af;
|
||||||
|
- hints.ai_socktype = si.si_socktype;
|
||||||
|
- hints.ai_protocol = si.si_proto;
|
||||||
|
- }
|
||||||
|
if (nconf->nc_semantics == NC_TPI_CLTS) {
|
||||||
|
+ int nhostsbak;
|
||||||
|
+ int checkbind;
|
||||||
|
+
|
||||||
|
/*
|
||||||
|
* If no hosts were specified, just bind to INADDR_ANY. Otherwise
|
||||||
|
* make sure 127.0.0.1 is added to the list.
|
||||||
|
@@ -343,9 +498,9 @@ init_transport(struct netconfig *nconf)
|
||||||
|
if (nhostsbak == 1)
|
||||||
|
hosts[0] = "*";
|
||||||
|
else {
|
||||||
|
- if (hints.ai_family == AF_INET) {
|
||||||
|
+ if (si.si_af == AF_INET) {
|
||||||
|
hosts[nhostsbak - 1] = "127.0.0.1";
|
||||||
|
- } else if (hints.ai_family == AF_INET6) {
|
||||||
|
+ } else if (si.si_af == AF_INET6) {
|
||||||
|
hosts[nhostsbak - 1] = "::1";
|
||||||
|
} else
|
||||||
|
return 1;
|
||||||
|
@@ -356,47 +511,9 @@ init_transport(struct netconfig *nconf)
|
||||||
|
*/
|
||||||
|
checkbind = 0;
|
||||||
|
while (nhostsbak > 0) {
|
||||||
|
- --nhostsbak;
|
||||||
|
- /*
|
||||||
|
- * XXX - using RPC library internal functions.
|
||||||
|
- */
|
||||||
|
- if ((fd = __rpc_nconf2fd(nconf)) < 0) {
|
||||||
|
- syslog(LOG_ERR, "cannot create socket for %s",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- return (1);
|
||||||
|
- }
|
||||||
|
+ int r;
|
||||||
|
|
||||||
|
- hints.ai_flags &= ~AI_NUMERICHOST;
|
||||||
|
- switch (hints.ai_family) {
|
||||||
|
- case AF_INET:
|
||||||
|
- if (inet_pton(AF_INET, hosts[nhostsbak],
|
||||||
|
- host_addr) == 1) {
|
||||||
|
- hints.ai_flags |= AI_NUMERICHOST;
|
||||||
|
- } else {
|
||||||
|
- /*
|
||||||
|
- * Skip if we have an AF_INET6 adress.
|
||||||
|
- */
|
||||||
|
- if (inet_pton(AF_INET6,
|
||||||
|
- hosts[nhostsbak], host_addr) == 1)
|
||||||
|
- continue;
|
||||||
|
- }
|
||||||
|
- break;
|
||||||
|
- case AF_INET6:
|
||||||
|
- if (inet_pton(AF_INET6, hosts[nhostsbak],
|
||||||
|
- host_addr) == 1) {
|
||||||
|
- hints.ai_flags |= AI_NUMERICHOST;
|
||||||
|
- } else {
|
||||||
|
- /*
|
||||||
|
- * Skip if we have an AF_INET adress.
|
||||||
|
- */
|
||||||
|
- if (inet_pton(AF_INET, hosts[nhostsbak],
|
||||||
|
- host_addr) == 1)
|
||||||
|
- continue;
|
||||||
|
- }
|
||||||
|
- break;
|
||||||
|
- default:
|
||||||
|
- break;
|
||||||
|
- }
|
||||||
|
+ --nhostsbak;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If no hosts were specified, just bind to INADDR_ANY
|
||||||
|
@@ -404,68 +521,14 @@ init_transport(struct netconfig *nconf)
|
||||||
|
if (strcmp("*", hosts[nhostsbak]) == 0)
|
||||||
|
hosts[nhostsbak] = NULL;
|
||||||
|
|
||||||
|
- if ((aicode = getaddrinfo(hosts[nhostsbak],
|
||||||
|
- servname, &hints, &res)) != 0) {
|
||||||
|
- if ((aicode = getaddrinfo(hosts[nhostsbak],
|
||||||
|
- "portmapper", &hints, &res)) != 0) {
|
||||||
|
- syslog(LOG_ERR,
|
||||||
|
- "cannot get local address for %s: %s",
|
||||||
|
- nconf->nc_netid, gai_strerror(aicode));
|
||||||
|
- continue;
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
- addrlen = res->ai_addrlen;
|
||||||
|
- sa = (struct sockaddr *)res->ai_addr;
|
||||||
|
- oldmask = umask(S_IXUSR|S_IXGRP|S_IXOTH);
|
||||||
|
- if (bind(fd, sa, addrlen) != 0) {
|
||||||
|
- syslog(LOG_ERR, "cannot bind %s on %s: %m",
|
||||||
|
- (hosts[nhostsbak] == NULL) ? "*" :
|
||||||
|
- hosts[nhostsbak], nconf->nc_netid);
|
||||||
|
- if (res != NULL)
|
||||||
|
- freeaddrinfo(res);
|
||||||
|
+ memset(&taddr, 0, sizeof(taddr));
|
||||||
|
+
|
||||||
|
+ r = create_transport_socket(nconf, hosts[nhostsbak], &taddr.addr, &fd);
|
||||||
|
+ if (r < 0)
|
||||||
|
+ goto error;
|
||||||
|
+ if (r == 0)
|
||||||
|
continue;
|
||||||
|
- } else
|
||||||
|
- checkbind++;
|
||||||
|
- (void) umask(oldmask);
|
||||||
|
-
|
||||||
|
- /* Copy the address */
|
||||||
|
- taddr.addr.maxlen = taddr.addr.len = addrlen;
|
||||||
|
- taddr.addr.buf = malloc(addrlen);
|
||||||
|
- if (taddr.addr.buf == NULL) {
|
||||||
|
- syslog(LOG_ERR,
|
||||||
|
- "cannot allocate memory for %s address",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- if (res != NULL)
|
||||||
|
- freeaddrinfo(res);
|
||||||
|
- return 1;
|
||||||
|
- }
|
||||||
|
- memcpy(taddr.addr.buf, sa, addrlen);
|
||||||
|
-#ifdef RPCBIND_DEBUG
|
||||||
|
- if (debugging) {
|
||||||
|
- /*
|
||||||
|
- * for debugging print out our universal
|
||||||
|
- * address
|
||||||
|
- */
|
||||||
|
- char *uaddr;
|
||||||
|
- struct netbuf nb;
|
||||||
|
- int sa_size = 0;
|
||||||
|
-
|
||||||
|
- nb.buf = sa;
|
||||||
|
- switch( sa->sa_family){
|
||||||
|
- case AF_INET:
|
||||||
|
- sa_size = sizeof (struct sockaddr_in);
|
||||||
|
- break;
|
||||||
|
- case AF_INET6:
|
||||||
|
- sa_size = sizeof (struct sockaddr_in6);
|
||||||
|
- break;
|
||||||
|
- }
|
||||||
|
- nb.len = nb.maxlen = sa_size;
|
||||||
|
- uaddr = taddr2uaddr(nconf, &nb);
|
||||||
|
- (void) fprintf(stderr,
|
||||||
|
- "rpcbind : my address is %s\n", uaddr);
|
||||||
|
- (void) free(uaddr);
|
||||||
|
- }
|
||||||
|
-#endif
|
||||||
|
+
|
||||||
|
my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr,
|
||||||
|
RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
||||||
|
if (my_xprt == (SVCXPRT *)NULL) {
|
||||||
|
@@ -473,84 +536,15 @@ init_transport(struct netconfig *nconf)
|
||||||
|
nconf->nc_netid);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
+ checkbind = 1;
|
||||||
|
+ fd = -1;
|
||||||
|
}
|
||||||
|
if (!checkbind)
|
||||||
|
return 1;
|
||||||
|
} else { /* NC_TPI_COTS */
|
||||||
|
- if ((fd = __rpc_nconf2fd(nconf)) < 0) {
|
||||||
|
- syslog(LOG_ERR, "cannot create socket for %s",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- return (1);
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- if ((strcmp(nconf->nc_netid, "local") != 0) &&
|
||||||
|
- (strcmp(nconf->nc_netid, "unix") != 0)) {
|
||||||
|
- if ((aicode = getaddrinfo(NULL, servname, &hints, &res))!= 0) {
|
||||||
|
- if ((aicode = getaddrinfo(NULL, "portmapper", &hints, &res))!= 0) {
|
||||||
|
- printf("cannot get local address for %s: %s", nconf->nc_netid, gai_strerror(aicode));
|
||||||
|
- syslog(LOG_ERR,
|
||||||
|
- "cannot get local address for %s: %s",
|
||||||
|
- nconf->nc_netid, gai_strerror(aicode));
|
||||||
|
- return 1;
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
- addrlen = res->ai_addrlen;
|
||||||
|
- sa = (struct sockaddr *)res->ai_addr;
|
||||||
|
- }
|
||||||
|
- oldmask = umask(S_IXUSR|S_IXGRP|S_IXOTH);
|
||||||
|
- __rpc_fd2sockinfo(fd, &si);
|
||||||
|
- if (setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &on,
|
||||||
|
- sizeof(on)) != 0) {
|
||||||
|
- syslog(LOG_ERR, "cannot set SO_REUSEADDR on %s",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- if (res != NULL)
|
||||||
|
- freeaddrinfo(res);
|
||||||
|
- return 1;
|
||||||
|
- }
|
||||||
|
- if (bind(fd, sa, addrlen) < 0) {
|
||||||
|
- syslog(LOG_ERR, "cannot bind %s: %m", nconf->nc_netid);
|
||||||
|
- if (res != NULL)
|
||||||
|
- freeaddrinfo(res);
|
||||||
|
- return 1;
|
||||||
|
- }
|
||||||
|
- (void) umask(oldmask);
|
||||||
|
-
|
||||||
|
- /* Copy the address */
|
||||||
|
- taddr.addr.len = taddr.addr.maxlen = addrlen;
|
||||||
|
- taddr.addr.buf = malloc(addrlen);
|
||||||
|
- if (taddr.addr.buf == NULL) {
|
||||||
|
- syslog(LOG_ERR, "cannot allocate memory for %s address",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- if (res != NULL)
|
||||||
|
- freeaddrinfo(res);
|
||||||
|
- return 1;
|
||||||
|
- }
|
||||||
|
- memcpy(taddr.addr.buf, sa, addrlen);
|
||||||
|
-#ifdef RPCBIND_DEBUG
|
||||||
|
- if (debugging) {
|
||||||
|
- /* for debugging print out our universal address */
|
||||||
|
- char *uaddr;
|
||||||
|
- struct netbuf nb;
|
||||||
|
- int sa_size2 = 0;
|
||||||
|
-
|
||||||
|
- nb.buf = sa;
|
||||||
|
- switch( sa->sa_family){
|
||||||
|
- case AF_INET:
|
||||||
|
- sa_size2 = sizeof (struct sockaddr_in);
|
||||||
|
- break;
|
||||||
|
- case AF_INET6:
|
||||||
|
- sa_size2 = sizeof (struct sockaddr_in6);
|
||||||
|
- break;
|
||||||
|
- }
|
||||||
|
- nb.len = nb.maxlen = sa_size2;
|
||||||
|
- uaddr = taddr2uaddr(nconf, &nb);
|
||||||
|
- (void) fprintf(stderr, "rpcbind : my address is %s\n",
|
||||||
|
- uaddr);
|
||||||
|
- (void) free(uaddr);
|
||||||
|
- }
|
||||||
|
-#endif
|
||||||
|
-
|
||||||
|
- listen(fd, SOMAXCONN);
|
||||||
|
+ memset(&taddr, 0, sizeof(taddr));
|
||||||
|
+ if (create_transport_socket(nconf, NULL, &taddr.addr, &fd) <= 0)
|
||||||
|
+ goto error;
|
||||||
|
|
||||||
|
my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr, RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
||||||
|
if (my_xprt == (SVCXPRT *)NULL) {
|
||||||
|
@@ -682,7 +676,8 @@ init_transport(struct netconfig *nconf)
|
||||||
|
}
|
||||||
|
return (0);
|
||||||
|
error:
|
||||||
|
- close(fd);
|
||||||
|
+ if (fd >= 0)
|
||||||
|
+ close(fd);
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
249
0007-init_transport-move-the-registration-code-into-a-sep.patch
Normal file
249
0007-init_transport-move-the-registration-code-into-a-sep.patch
Normal file
@ -0,0 +1,249 @@
|
|||||||
|
From a43a3b1ab5545d835af2867c343ee195a6256665 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 20 Aug 2013 09:49:15 +0200
|
||||||
|
Subject: [PATCH 07/13] init_transport: move the registration code into a
|
||||||
|
separate function
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
src/rpcbind.c | 216 +++++++++++++++++++++++++++++++---------------------------
|
||||||
|
1 file changed, 116 insertions(+), 100 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
||||||
|
index a7dcc0e..25d12c9 100644
|
||||||
|
--- a/src/rpcbind.c
|
||||||
|
+++ b/src/rpcbind.c
|
||||||
|
@@ -447,6 +447,120 @@ skip:
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
+static int
|
||||||
|
+rpcbind_register_transport(struct netconfig *nconf, SVCXPRT *xprt, struct netbuf *bind_addr)
|
||||||
|
+{
|
||||||
|
+ struct __rpc_sockinfo si;
|
||||||
|
+ int status;
|
||||||
|
+
|
||||||
|
+ (void) __rpc_nconf2sockinfo(nconf, &si);
|
||||||
|
+
|
||||||
|
+#ifdef PORTMAP
|
||||||
|
+ /*
|
||||||
|
+ * Register both the versions for tcp/ip, udp/ip.
|
||||||
|
+ */
|
||||||
|
+ if (si.si_af == AF_INET &&
|
||||||
|
+ (si.si_proto == IPPROTO_TCP || si.si_proto == IPPROTO_UDP)) {
|
||||||
|
+ struct pmaplist *pml;
|
||||||
|
+
|
||||||
|
+ pml = malloc(sizeof (struct pmaplist));
|
||||||
|
+ if (pml == NULL) {
|
||||||
|
+ syslog(LOG_ERR, "no memory!");
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+ pml->pml_map.pm_prog = PMAPPROG;
|
||||||
|
+ pml->pml_map.pm_vers = PMAPVERS;
|
||||||
|
+ pml->pml_map.pm_port = PMAPPORT;
|
||||||
|
+ pml->pml_map.pm_prot = si.si_proto;
|
||||||
|
+
|
||||||
|
+ switch (si.si_proto) {
|
||||||
|
+ case IPPROTO_TCP:
|
||||||
|
+ tcptrans = strdup(nconf->nc_netid);
|
||||||
|
+ break;
|
||||||
|
+ case IPPROTO_UDP:
|
||||||
|
+ udptrans = strdup(nconf->nc_netid);
|
||||||
|
+ break;
|
||||||
|
+ }
|
||||||
|
+ pml->pml_next = list_pml;
|
||||||
|
+ list_pml = pml;
|
||||||
|
+
|
||||||
|
+ /* Add version 3 information */
|
||||||
|
+ pml = malloc(sizeof (struct pmaplist));
|
||||||
|
+ if (pml == NULL) {
|
||||||
|
+ syslog(LOG_ERR, "no memory!");
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+ pml->pml_map = list_pml->pml_map;
|
||||||
|
+ pml->pml_map.pm_vers = RPCBVERS;
|
||||||
|
+ pml->pml_next = list_pml;
|
||||||
|
+ list_pml = pml;
|
||||||
|
+
|
||||||
|
+ /* Add version 4 information */
|
||||||
|
+ pml = malloc (sizeof (struct pmaplist));
|
||||||
|
+ if (pml == NULL) {
|
||||||
|
+ syslog(LOG_ERR, "no memory!");
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+ pml->pml_map = list_pml->pml_map;
|
||||||
|
+ pml->pml_map.pm_vers = RPCBVERS4;
|
||||||
|
+ pml->pml_next = list_pml;
|
||||||
|
+ list_pml = pml;
|
||||||
|
+
|
||||||
|
+ /* Also add version 2 stuff to rpcbind list */
|
||||||
|
+ rbllist_add(PMAPPROG, PMAPVERS, nconf, bind_addr);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* We need to support portmap over IPv4. It makes sense to
|
||||||
|
+ * support it over AF_LOCAL as well, because that allows
|
||||||
|
+ * rpcbind to identify the owner of a socket much better
|
||||||
|
+ * than by relying on privileged ports to tell root from
|
||||||
|
+ * non-root users. */
|
||||||
|
+ if (si.si_af == AF_INET || si.si_af == AF_LOCAL) {
|
||||||
|
+ if (!svc_register(xprt, PMAPPROG, PMAPVERS, pmap_service, 0)) {
|
||||||
|
+ syslog(LOG_ERR, "could not register on %s",
|
||||||
|
+ nconf->nc_netid);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
+ /* version 3 registration */
|
||||||
|
+ if (!svc_reg(xprt, RPCBPROG, RPCBVERS, rpcb_service_3, NULL)) {
|
||||||
|
+ syslog(LOG_ERR, "could not register %s version 3",
|
||||||
|
+ nconf->nc_netid);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+ rbllist_add(RPCBPROG, RPCBVERS, nconf, bind_addr);
|
||||||
|
+
|
||||||
|
+ /* version 4 registration */
|
||||||
|
+ if (!svc_reg(xprt, RPCBPROG, RPCBVERS4, rpcb_service_4, NULL)) {
|
||||||
|
+ syslog(LOG_ERR, "could not register %s version 4",
|
||||||
|
+ nconf->nc_netid);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+ rbllist_add(RPCBPROG, RPCBVERS4, nconf, bind_addr);
|
||||||
|
+
|
||||||
|
+ /* decide if bound checking works for this transport */
|
||||||
|
+ status = add_bndlist(nconf, bind_addr);
|
||||||
|
+
|
||||||
|
+#ifdef RPCBIND_DEBUG
|
||||||
|
+ if (debugging) {
|
||||||
|
+ if (status < 0) {
|
||||||
|
+ fprintf(stderr, "Error in finding bind status for %s\n",
|
||||||
|
+ nconf->nc_netid);
|
||||||
|
+ } else if (status == 0) {
|
||||||
|
+ fprintf(stderr, "check binding for %s\n",
|
||||||
|
+ nconf->nc_netid);
|
||||||
|
+ } else if (status > 0) {
|
||||||
|
+ fprintf(stderr, "No check binding for %s\n",
|
||||||
|
+ nconf->nc_netid);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
+ return 1;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
/*
|
||||||
|
* Adds the entry into the rpcbind database.
|
||||||
|
* If PORTMAP, then for UDP and TCP, it adds the entries for version 2 also
|
||||||
|
@@ -554,107 +668,9 @@ init_transport(struct netconfig *nconf)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
-#ifdef PORTMAP
|
||||||
|
- /*
|
||||||
|
- * Register both the versions for tcp/ip, udp/ip.
|
||||||
|
- */
|
||||||
|
- if (si.si_af == AF_INET &&
|
||||||
|
- (si.si_proto == IPPROTO_TCP || si.si_proto == IPPROTO_UDP)) {
|
||||||
|
- struct pmaplist *pml;
|
||||||
|
-
|
||||||
|
- pml = malloc(sizeof (struct pmaplist));
|
||||||
|
- if (pml == NULL) {
|
||||||
|
- syslog(LOG_ERR, "no memory!");
|
||||||
|
- exit(1);
|
||||||
|
- }
|
||||||
|
- pml->pml_map.pm_prog = PMAPPROG;
|
||||||
|
- pml->pml_map.pm_vers = PMAPVERS;
|
||||||
|
- pml->pml_map.pm_port = PMAPPORT;
|
||||||
|
- pml->pml_map.pm_prot = si.si_proto;
|
||||||
|
-
|
||||||
|
- switch (si.si_proto) {
|
||||||
|
- case IPPROTO_TCP:
|
||||||
|
- tcptrans = strdup(nconf->nc_netid);
|
||||||
|
- break;
|
||||||
|
- case IPPROTO_UDP:
|
||||||
|
- udptrans = strdup(nconf->nc_netid);
|
||||||
|
- break;
|
||||||
|
- }
|
||||||
|
- pml->pml_next = list_pml;
|
||||||
|
- list_pml = pml;
|
||||||
|
-
|
||||||
|
- /* Add version 3 information */
|
||||||
|
- pml = malloc(sizeof (struct pmaplist));
|
||||||
|
- if (pml == NULL) {
|
||||||
|
- syslog(LOG_ERR, "no memory!");
|
||||||
|
- exit(1);
|
||||||
|
- }
|
||||||
|
- pml->pml_map = list_pml->pml_map;
|
||||||
|
- pml->pml_map.pm_vers = RPCBVERS;
|
||||||
|
- pml->pml_next = list_pml;
|
||||||
|
- list_pml = pml;
|
||||||
|
-
|
||||||
|
- /* Add version 4 information */
|
||||||
|
- pml = malloc (sizeof (struct pmaplist));
|
||||||
|
- if (pml == NULL) {
|
||||||
|
- syslog(LOG_ERR, "no memory!");
|
||||||
|
- exit(1);
|
||||||
|
- }
|
||||||
|
- pml->pml_map = list_pml->pml_map;
|
||||||
|
- pml->pml_map.pm_vers = RPCBVERS4;
|
||||||
|
- pml->pml_next = list_pml;
|
||||||
|
- list_pml = pml;
|
||||||
|
-
|
||||||
|
- /* Also add version 2 stuff to rpcbind list */
|
||||||
|
- rbllist_add(PMAPPROG, PMAPVERS, nconf, &taddr.addr);
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- /* We need to support portmap over IPv4. It makes sense to
|
||||||
|
- * support it over AF_LOCAL as well, because that allows
|
||||||
|
- * rpcbind to identify the owner of a socket much better
|
||||||
|
- * than by relying on privileged ports to tell root from
|
||||||
|
- * non-root users. */
|
||||||
|
- if (si.si_af == AF_INET || si.si_af == AF_LOCAL) {
|
||||||
|
- if (!svc_register(my_xprt, PMAPPROG, PMAPVERS, pmap_service, 0)) {
|
||||||
|
- syslog(LOG_ERR, "could not register on %s",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- goto error;
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
-#endif
|
||||||
|
-
|
||||||
|
- /* version 3 registration */
|
||||||
|
- if (!svc_reg(my_xprt, RPCBPROG, RPCBVERS, rpcb_service_3, NULL)) {
|
||||||
|
- syslog(LOG_ERR, "could not register %s version 3",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- goto error;
|
||||||
|
- }
|
||||||
|
- rbllist_add(RPCBPROG, RPCBVERS, nconf, &taddr.addr);
|
||||||
|
-
|
||||||
|
- /* version 4 registration */
|
||||||
|
- if (!svc_reg(my_xprt, RPCBPROG, RPCBVERS4, rpcb_service_4, NULL)) {
|
||||||
|
- syslog(LOG_ERR, "could not register %s version 4",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- goto error;
|
||||||
|
- }
|
||||||
|
- rbllist_add(RPCBPROG, RPCBVERS4, nconf, &taddr.addr);
|
||||||
|
+ if (!rpcbind_register_transport(nconf, my_xprt, &taddr.addr))
|
||||||
|
+ return (1);
|
||||||
|
|
||||||
|
- /* decide if bound checking works for this transport */
|
||||||
|
- status = add_bndlist(nconf, &taddr.addr);
|
||||||
|
-#ifdef RPCBIND_DEBUG
|
||||||
|
- if (debugging) {
|
||||||
|
- if (status < 0) {
|
||||||
|
- fprintf(stderr, "Error in finding bind status for %s\n",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- } else if (status == 0) {
|
||||||
|
- fprintf(stderr, "check binding for %s\n",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- } else if (status > 0) {
|
||||||
|
- fprintf(stderr, "No check binding for %s\n",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
-#endif
|
||||||
|
/*
|
||||||
|
* rmtcall only supported on CLTS transports for now.
|
||||||
|
*/
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
141
0008-Fix-the-behavior-when-specifying-the-h-option.patch
Normal file
141
0008-Fix-the-behavior-when-specifying-the-h-option.patch
Normal file
@ -0,0 +1,141 @@
|
|||||||
|
From 2a825515a2b6304e27f0e28fd5da562d44d6cbfe Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 20 Aug 2013 09:58:51 +0200
|
||||||
|
Subject: [PATCH 08/13] Fix the behavior when specifying the -h option
|
||||||
|
|
||||||
|
Currently, when specifying the "-h" option, rpcbind will try to create
|
||||||
|
sockets for all specified addresses, plus the loopback address. However,
|
||||||
|
it will only register its programs on the last SVCXPRT created, which
|
||||||
|
will usually be the first address specified via -h.
|
||||||
|
|
||||||
|
This patch fixes this problem by introducing a new function that creates
|
||||||
|
the socket *and* registers all programs, and use that from the while
|
||||||
|
loop.
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
src/rpcbind.c | 79 ++++++++++++++++++++++++++++++++---------------------------
|
||||||
|
1 file changed, 43 insertions(+), 36 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
||||||
|
index 25d12c9..c3679e2 100644
|
||||||
|
--- a/src/rpcbind.c
|
||||||
|
+++ b/src/rpcbind.c
|
||||||
|
@@ -562,6 +562,43 @@ rpcbind_register_transport(struct netconfig *nconf, SVCXPRT *xprt, struct netbuf
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
+ * This will create a server socket for the given netid, bound to the
|
||||||
|
+ * address specified by @hostname
|
||||||
|
+ *
|
||||||
|
+ * Return value:
|
||||||
|
+ * 1: success
|
||||||
|
+ * 0: error - ignore this hostname
|
||||||
|
+ * <0: error - ignore this netid
|
||||||
|
+ */
|
||||||
|
+static int
|
||||||
|
+rpcbind_init_endpoint(struct netconfig *nconf, const char *hostname)
|
||||||
|
+{
|
||||||
|
+ struct t_bind taddr;
|
||||||
|
+ SVCXPRT *my_xprt = NULL;
|
||||||
|
+ int r, fd = -1;
|
||||||
|
+
|
||||||
|
+ memset(&taddr, 0, sizeof(taddr));
|
||||||
|
+
|
||||||
|
+ r = create_transport_socket(nconf, hostname, &taddr.addr, &fd);
|
||||||
|
+ if (r <= 0)
|
||||||
|
+ return r;
|
||||||
|
+
|
||||||
|
+ my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr, RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
||||||
|
+ if (my_xprt == (SVCXPRT *)NULL) {
|
||||||
|
+ syslog(LOG_ERR, "%s: could not create service", nconf->nc_netid);
|
||||||
|
+ close(fd);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (!rpcbind_register_transport(nconf, my_xprt, &taddr.addr)) {
|
||||||
|
+ svc_destroy(my_xprt);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return 1;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+/*
|
||||||
|
* Adds the entry into the rpcbind database.
|
||||||
|
* If PORTMAP, then for UDP and TCP, it adds the entries for version 2 also
|
||||||
|
* Returns 0 if succeeds, else fails
|
||||||
|
@@ -569,10 +606,7 @@ rpcbind_register_transport(struct netconfig *nconf, SVCXPRT *xprt, struct netbuf
|
||||||
|
static int
|
||||||
|
init_transport(struct netconfig *nconf)
|
||||||
|
{
|
||||||
|
- int fd = -1;
|
||||||
|
- struct t_bind taddr;
|
||||||
|
struct __rpc_sockinfo si;
|
||||||
|
- SVCXPRT *my_xprt = NULL;
|
||||||
|
int status; /* bound checking ? */
|
||||||
|
|
||||||
|
if ((nconf->nc_semantics != NC_TPI_CLTS) &&
|
||||||
|
@@ -635,42 +669,19 @@ init_transport(struct netconfig *nconf)
|
||||||
|
if (strcmp("*", hosts[nhostsbak]) == 0)
|
||||||
|
hosts[nhostsbak] = NULL;
|
||||||
|
|
||||||
|
- memset(&taddr, 0, sizeof(taddr));
|
||||||
|
-
|
||||||
|
- r = create_transport_socket(nconf, hosts[nhostsbak], &taddr.addr, &fd);
|
||||||
|
+ r = rpcbind_init_endpoint(nconf, hosts[nhostsbak]);
|
||||||
|
if (r < 0)
|
||||||
|
- goto error;
|
||||||
|
- if (r == 0)
|
||||||
|
- continue;
|
||||||
|
-
|
||||||
|
- my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr,
|
||||||
|
- RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
||||||
|
- if (my_xprt == (SVCXPRT *)NULL) {
|
||||||
|
- syslog(LOG_ERR, "%s: could not create service",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- goto error;
|
||||||
|
- }
|
||||||
|
- checkbind = 1;
|
||||||
|
- fd = -1;
|
||||||
|
+ return 1;
|
||||||
|
+ if (r > 0)
|
||||||
|
+ checkbind = 1;
|
||||||
|
}
|
||||||
|
if (!checkbind)
|
||||||
|
return 1;
|
||||||
|
} else { /* NC_TPI_COTS */
|
||||||
|
- memset(&taddr, 0, sizeof(taddr));
|
||||||
|
- if (create_transport_socket(nconf, NULL, &taddr.addr, &fd) <= 0)
|
||||||
|
- goto error;
|
||||||
|
-
|
||||||
|
- my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr, RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
||||||
|
- if (my_xprt == (SVCXPRT *)NULL) {
|
||||||
|
- syslog(LOG_ERR, "%s: could not create service",
|
||||||
|
- nconf->nc_netid);
|
||||||
|
- goto error;
|
||||||
|
- }
|
||||||
|
+ if (rpcbind_init_endpoint(nconf, NULL) <= 0)
|
||||||
|
+ return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (!rpcbind_register_transport(nconf, my_xprt, &taddr.addr))
|
||||||
|
- return (1);
|
||||||
|
-
|
||||||
|
/*
|
||||||
|
* rmtcall only supported on CLTS transports for now.
|
||||||
|
*/
|
||||||
|
@@ -691,10 +702,6 @@ init_transport(struct netconfig *nconf)
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
return (0);
|
||||||
|
-error:
|
||||||
|
- if (fd >= 0)
|
||||||
|
- close(fd);
|
||||||
|
- return (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
104
0009-Clean-up-the-way-we-handle-the-h-option-in-init_tran.patch
Normal file
104
0009-Clean-up-the-way-we-handle-the-h-option-in-init_tran.patch
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
From 734101ba29f0b169d72e8ec6de6d924922f1583c Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 20 Aug 2013 10:10:41 +0200
|
||||||
|
Subject: [PATCH 09/13] Clean up the way we handle the -h option in
|
||||||
|
init_transport
|
||||||
|
|
||||||
|
There's some odd realloc()ing going on, which is plain ugly.
|
||||||
|
Make the code a little more readable.
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
src/rpcbind.c | 66 +++++++++++++++++++++++++++--------------------------------
|
||||||
|
1 file changed, 30 insertions(+), 36 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
||||||
|
index c3679e2..1d59362 100644
|
||||||
|
--- a/src/rpcbind.c
|
||||||
|
+++ b/src/rpcbind.c
|
||||||
|
@@ -632,52 +632,46 @@ init_transport(struct netconfig *nconf)
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (nconf->nc_semantics == NC_TPI_CLTS) {
|
||||||
|
- int nhostsbak;
|
||||||
|
- int checkbind;
|
||||||
|
+ /* Check if the -h option was used to specify addresses to bind to.
|
||||||
|
+ * The original purpose was to allow multihomed hosts to function
|
||||||
|
+ * properly, making the reply originate from the same IP address
|
||||||
|
+ * that it was sent to. We're solving this differently in the meantime
|
||||||
|
+ * (using PKTINFO magic in libtirpc), but there may be other uses for
|
||||||
|
+ * this option, like restricting rpcbind to certain "public" interfaces
|
||||||
|
+ */
|
||||||
|
+ if (nhosts != 0 && nconf->nc_semantics == NC_TPI_CLTS) {
|
||||||
|
+ int numbound = 0, n, r;
|
||||||
|
|
||||||
|
- /*
|
||||||
|
- * If no hosts were specified, just bind to INADDR_ANY. Otherwise
|
||||||
|
- * make sure 127.0.0.1 is added to the list.
|
||||||
|
- */
|
||||||
|
- nhostsbak = nhosts;
|
||||||
|
- nhostsbak++;
|
||||||
|
- hosts = realloc(hosts, nhostsbak * sizeof(char *));
|
||||||
|
- if (nhostsbak == 1)
|
||||||
|
- hosts[0] = "*";
|
||||||
|
- else {
|
||||||
|
- if (si.si_af == AF_INET) {
|
||||||
|
- hosts[nhostsbak - 1] = "127.0.0.1";
|
||||||
|
- } else if (si.si_af == AF_INET6) {
|
||||||
|
- hosts[nhostsbak - 1] = "::1";
|
||||||
|
- } else
|
||||||
|
- return 1;
|
||||||
|
- }
|
||||||
|
+ /* Ensure that we always bind to loopback */
|
||||||
|
+ switch (si.si_af) {
|
||||||
|
+ case AF_INET:
|
||||||
|
+ if (rpcbind_init_endpoint(nconf, "127.0.0.1") > 0)
|
||||||
|
+ numbound++;
|
||||||
|
+ break;
|
||||||
|
|
||||||
|
- /*
|
||||||
|
- * Bind to specific IPs if asked to
|
||||||
|
- */
|
||||||
|
- checkbind = 0;
|
||||||
|
- while (nhostsbak > 0) {
|
||||||
|
- int r;
|
||||||
|
+ case AF_INET6:
|
||||||
|
+ if (rpcbind_init_endpoint(nconf, "::1") > 0)
|
||||||
|
+ numbound++;
|
||||||
|
+ break;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
- --nhostsbak;
|
||||||
|
+ for (n = 0; n < nhosts; ++n) {
|
||||||
|
+ const char *hostname = hosts[n];
|
||||||
|
|
||||||
|
- /*
|
||||||
|
- * If no hosts were specified, just bind to INADDR_ANY
|
||||||
|
- */
|
||||||
|
- if (strcmp("*", hosts[nhostsbak]) == 0)
|
||||||
|
- hosts[nhostsbak] = NULL;
|
||||||
|
+ /* In case someone gets the idea to specify "-h '*'" */
|
||||||
|
+ if (strcmp("*", hostname) == 0)
|
||||||
|
+ hostname = NULL;
|
||||||
|
|
||||||
|
- r = rpcbind_init_endpoint(nconf, hosts[nhostsbak]);
|
||||||
|
+ r = rpcbind_init_endpoint(nconf, hostname);
|
||||||
|
if (r < 0)
|
||||||
|
return 1;
|
||||||
|
if (r > 0)
|
||||||
|
- checkbind = 1;
|
||||||
|
+ numbound++;
|
||||||
|
}
|
||||||
|
- if (!checkbind)
|
||||||
|
+
|
||||||
|
+ if (numbound == 0)
|
||||||
|
return 1;
|
||||||
|
- } else { /* NC_TPI_COTS */
|
||||||
|
+ } else {
|
||||||
|
if (rpcbind_init_endpoint(nconf, NULL) <= 0)
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
372
0010-Support-systemd-activation.patch
Normal file
372
0010-Support-systemd-activation.patch
Normal file
@ -0,0 +1,372 @@
|
|||||||
|
From c3ec796dd8f177a3c6ab9b76de490dbfe2c86476 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 20 Aug 2013 11:26:42 +0200
|
||||||
|
Subject: [PATCH 10/13] Support systemd activation.
|
||||||
|
|
||||||
|
This code is loosely based on previous work by Tom Gundersen <teg@jklm.no>.
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
Makefile.am | 15 ++++
|
||||||
|
configure.ac | 11 +++
|
||||||
|
src/rpcbind.c | 172 ++++++++++++++++++++++++++++++++++++---------
|
||||||
|
systemd/.gitignore | 1 +
|
||||||
|
systemd/rpcbind.service.in | 9 +++
|
||||||
|
systemd/rpcbind.socket | 12 ++++
|
||||||
|
6 files changed, 188 insertions(+), 32 deletions(-)
|
||||||
|
create mode 100644 systemd/.gitignore
|
||||||
|
create mode 100644 systemd/rpcbind.service.in
|
||||||
|
create mode 100644 systemd/rpcbind.socket
|
||||||
|
|
||||||
|
diff --git a/Makefile.am b/Makefile.am
|
||||||
|
index d10c906..df755dd 100644
|
||||||
|
--- a/Makefile.am
|
||||||
|
+++ b/Makefile.am
|
||||||
|
@@ -38,6 +38,21 @@ rpcbind_SOURCES = \
|
||||||
|
src/warmstart.c
|
||||||
|
rpcbind_LDADD = $(TIRPC_LIBS)
|
||||||
|
|
||||||
|
+if SYSTEMD
|
||||||
|
+AM_CPPFLAGS += $(SYSTEMD_CFLAGS) -DSYSTEMD
|
||||||
|
+
|
||||||
|
+rpcbind_LDADD += $(SYSTEMD_LIBS)
|
||||||
|
+
|
||||||
|
+systemd/rpcbind.service: systemd/rpcbind.service.in Makefile
|
||||||
|
+ sed -e 's,@bindir\@,$(bindir),g' \
|
||||||
|
+ < $< > $@ || rm $@
|
||||||
|
+
|
||||||
|
+systemdsystemunit_DATA = \
|
||||||
|
+ systemd/rpcbind.service \
|
||||||
|
+ systemd/rpcbind.socket
|
||||||
|
+
|
||||||
|
+endif
|
||||||
|
+
|
||||||
|
rpcinfo_SOURCES = src/rpcinfo.c
|
||||||
|
rpcinfo_LDADD = $(TIRPC_LIBS)
|
||||||
|
|
||||||
|
diff --git a/configure.ac b/configure.ac
|
||||||
|
index 1cf42d3..a94933b 100644
|
||||||
|
--- a/configure.ac
|
||||||
|
+++ b/configure.ac
|
||||||
|
@@ -29,6 +29,17 @@ AC_SUBST([rpcuser], [$with_rpcuser])
|
||||||
|
|
||||||
|
PKG_CHECK_MODULES([TIRPC], [libtirpc])
|
||||||
|
|
||||||
|
+PKG_PROG_PKG_CONFIG
|
||||||
|
+AC_ARG_WITH([systemdsystemunitdir],
|
||||||
|
+ AS_HELP_STRING([--with-systemdsystemunitdir=DIR], [Directory for systemd service files]),
|
||||||
|
+ [], [with_systemdsystemunitdir=$($PKG_CONFIG --variable=systemdsystemunitdir systemd)])
|
||||||
|
+ if test "x$with_systemdsystemunitdir" != xno -a "x$with_systemdsystemunitdir" != "x"; then
|
||||||
|
+ AC_SUBST([systemdsystemunitdir], [$with_systemdsystemunitdir])
|
||||||
|
+ PKG_CHECK_MODULES([SYSTEMD], [libsystemd-daemon])
|
||||||
|
+ fi
|
||||||
|
+AM_CONDITIONAL(SYSTEMD, [test -n "$with_systemdsystemunitdir" -a "x$with_systemdsystemunitdir" != xno ])
|
||||||
|
+
|
||||||
|
+
|
||||||
|
AS_IF([test x$enable_libwrap = xyes], [
|
||||||
|
AC_CHECK_LIB([wrap], [hosts_access], ,
|
||||||
|
AC_MSG_ERROR([libwrap support requested but unable to find libwrap]))
|
||||||
|
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
||||||
|
index 1d59362..32e6deb 100644
|
||||||
|
--- a/src/rpcbind.c
|
||||||
|
+++ b/src/rpcbind.c
|
||||||
|
@@ -56,6 +56,9 @@
|
||||||
|
#include <netinet/in.h>
|
||||||
|
#endif
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
+#ifdef SYSTEMD
|
||||||
|
+#include <systemd/sd-daemon.h>
|
||||||
|
+#endif
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <netdb.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
@@ -100,6 +103,9 @@ int runasdaemon = 0;
|
||||||
|
int insecure = 0;
|
||||||
|
int oldstyle_local = 0;
|
||||||
|
int verboselog = 0;
|
||||||
|
+#ifdef SYSTEMD
|
||||||
|
+int systemd_activation = 0;
|
||||||
|
+#endif
|
||||||
|
|
||||||
|
char **hosts = NULL;
|
||||||
|
int nhosts = 0;
|
||||||
|
@@ -123,6 +129,10 @@ static char superuser[] = "superuser";
|
||||||
|
|
||||||
|
int main __P((int, char *[]));
|
||||||
|
|
||||||
|
+static void init_transports_daemon __P((void));
|
||||||
|
+#ifdef SYSTEMD
|
||||||
|
+static void init_transports_systemd __P((void));
|
||||||
|
+#endif
|
||||||
|
static int init_transport __P((struct netconfig *));
|
||||||
|
static void rbllist_add __P((rpcprog_t, rpcvers_t, struct netconfig *,
|
||||||
|
struct netbuf *));
|
||||||
|
@@ -132,11 +142,15 @@ static void parseargs __P((int, char *[]));
|
||||||
|
int
|
||||||
|
main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
- struct netconfig *nconf;
|
||||||
|
- void *nc_handle; /* Net config handle */
|
||||||
|
struct rlimit rl;
|
||||||
|
int maxrec = RPC_MAXDATASIZE;
|
||||||
|
|
||||||
|
+#ifdef SYSTEMD
|
||||||
|
+ /* See whether we've been activated by systemd */
|
||||||
|
+ if (sd_listen_fds(0) > 0)
|
||||||
|
+ systemd_activation = 1;
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
parseargs(argc, argv);
|
||||||
|
|
||||||
|
/* Check that another rpcbind isn't already running. */
|
||||||
|
@@ -167,29 +181,14 @@ main(int argc, char *argv[])
|
||||||
|
*/
|
||||||
|
__nss_configure_lookup("services", "files");
|
||||||
|
|
||||||
|
- nc_handle = setnetconfig(); /* open netconfig file */
|
||||||
|
- if (nc_handle == NULL) {
|
||||||
|
- syslog(LOG_ERR, "could not read /etc/netconfig");
|
||||||
|
- exit(1);
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- nconf = getnetconfigent("local");
|
||||||
|
- if (nconf == NULL)
|
||||||
|
- nconf = getnetconfigent("unix");
|
||||||
|
- if (nconf == NULL) {
|
||||||
|
- syslog(LOG_ERR, "%s: can't find local transport\n", argv[0]);
|
||||||
|
- exit(1);
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
rpc_control(RPC_SVC_CONNMAXREC_SET, &maxrec);
|
||||||
|
|
||||||
|
- init_transport(nconf);
|
||||||
|
-
|
||||||
|
- while ((nconf = getnetconfig(nc_handle))) {
|
||||||
|
- if (nconf->nc_flag & NC_VISIBLE)
|
||||||
|
- init_transport(nconf);
|
||||||
|
- }
|
||||||
|
- endnetconfig(nc_handle);
|
||||||
|
+#ifdef SYSTEMD
|
||||||
|
+ if (systemd_activation)
|
||||||
|
+ init_transports_systemd();
|
||||||
|
+ else
|
||||||
|
+#endif
|
||||||
|
+ init_transports_daemon();
|
||||||
|
|
||||||
|
#ifdef PORTMAP
|
||||||
|
if (!udptrans)
|
||||||
|
@@ -571,17 +570,29 @@ rpcbind_register_transport(struct netconfig *nconf, SVCXPRT *xprt, struct netbuf
|
||||||
|
* <0: error - ignore this netid
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
-rpcbind_init_endpoint(struct netconfig *nconf, const char *hostname)
|
||||||
|
+rpcbind_init_endpoint(struct netconfig *nconf, const char *hostname, int fd)
|
||||||
|
{
|
||||||
|
struct t_bind taddr;
|
||||||
|
SVCXPRT *my_xprt = NULL;
|
||||||
|
- int r, fd = -1;
|
||||||
|
+ int r;
|
||||||
|
|
||||||
|
memset(&taddr, 0, sizeof(taddr));
|
||||||
|
|
||||||
|
- r = create_transport_socket(nconf, hostname, &taddr.addr, &fd);
|
||||||
|
- if (r <= 0)
|
||||||
|
- return r;
|
||||||
|
+ if (fd < 0) {
|
||||||
|
+ r = create_transport_socket(nconf, hostname, &taddr.addr, &fd);
|
||||||
|
+ if (r <= 0)
|
||||||
|
+ return r;
|
||||||
|
+ } else {
|
||||||
|
+ struct sockaddr_storage addr;
|
||||||
|
+ socklen_t alen = sizeof(addr);
|
||||||
|
+
|
||||||
|
+ if (getsockname(fd, (struct sockaddr *) &addr, &alen) < 0) {
|
||||||
|
+ syslog(LOG_ERR, "cannot get address for socket fd %d", fd);
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ sockaddr2netbuf((struct sockaddr *) &addr, alen, &taddr.addr);
|
||||||
|
+ }
|
||||||
|
|
||||||
|
my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr, RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
||||||
|
if (my_xprt == (SVCXPRT *)NULL) {
|
||||||
|
@@ -645,12 +656,12 @@ init_transport(struct netconfig *nconf)
|
||||||
|
/* Ensure that we always bind to loopback */
|
||||||
|
switch (si.si_af) {
|
||||||
|
case AF_INET:
|
||||||
|
- if (rpcbind_init_endpoint(nconf, "127.0.0.1") > 0)
|
||||||
|
+ if (rpcbind_init_endpoint(nconf, "127.0.0.1", -1) > 0)
|
||||||
|
numbound++;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case AF_INET6:
|
||||||
|
- if (rpcbind_init_endpoint(nconf, "::1") > 0)
|
||||||
|
+ if (rpcbind_init_endpoint(nconf, "::1", -1) > 0)
|
||||||
|
numbound++;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
@@ -662,7 +673,7 @@ init_transport(struct netconfig *nconf)
|
||||||
|
if (strcmp("*", hostname) == 0)
|
||||||
|
hostname = NULL;
|
||||||
|
|
||||||
|
- r = rpcbind_init_endpoint(nconf, hostname);
|
||||||
|
+ r = rpcbind_init_endpoint(nconf, hostname, -1);
|
||||||
|
if (r < 0)
|
||||||
|
return 1;
|
||||||
|
if (r > 0)
|
||||||
|
@@ -672,7 +683,7 @@ init_transport(struct netconfig *nconf)
|
||||||
|
if (numbound == 0)
|
||||||
|
return 1;
|
||||||
|
} else {
|
||||||
|
- if (rpcbind_init_endpoint(nconf, NULL) <= 0)
|
||||||
|
+ if (rpcbind_init_endpoint(nconf, NULL, -1) <= 0)
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -699,6 +710,103 @@ init_transport(struct netconfig *nconf)
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
+init_transports_daemon(void)
|
||||||
|
+{
|
||||||
|
+ void *nc_handle;
|
||||||
|
+ struct netconfig *nconf;
|
||||||
|
+
|
||||||
|
+ nc_handle = setnetconfig(); /* open netconfig file */
|
||||||
|
+ if (nc_handle == NULL) {
|
||||||
|
+ syslog(LOG_ERR, "could not read /etc/netconfig");
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ nconf = getnetconfigent("local");
|
||||||
|
+ if (nconf == NULL)
|
||||||
|
+ nconf = getnetconfigent("unix");
|
||||||
|
+ if (nconf == NULL) {
|
||||||
|
+ syslog(LOG_ERR, "rpcbind: can't find local transport\n");
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ init_transport(nconf);
|
||||||
|
+
|
||||||
|
+ while ((nconf = getnetconfig(nc_handle))) {
|
||||||
|
+ if (nconf->nc_flag & NC_VISIBLE)
|
||||||
|
+ init_transport(nconf);
|
||||||
|
+ }
|
||||||
|
+ endnetconfig(nc_handle);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+#ifdef SYSTEMD
|
||||||
|
+static struct netconfig *
|
||||||
|
+sockinfo2nconf(void **handlep, const struct __rpc_sockinfo *match)
|
||||||
|
+{
|
||||||
|
+ struct netconfig *nconf;
|
||||||
|
+
|
||||||
|
+ if (*handlep)
|
||||||
|
+ endnetconfig(*handlep);
|
||||||
|
+ *handlep = setnetconfig();
|
||||||
|
+
|
||||||
|
+ while ((nconf = getnetconfig(*handlep))) {
|
||||||
|
+ struct __rpc_sockinfo si;
|
||||||
|
+
|
||||||
|
+ if (!__rpc_nconf2sockinfo(nconf, &si))
|
||||||
|
+ continue;
|
||||||
|
+
|
||||||
|
+ if (si.si_af == match->si_af
|
||||||
|
+ && si.si_socktype == match->si_socktype
|
||||||
|
+ && si.si_proto == match->si_proto)
|
||||||
|
+ return nconf;
|
||||||
|
+ }
|
||||||
|
+ return NULL;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void
|
||||||
|
+init_transports_systemd()
|
||||||
|
+{
|
||||||
|
+ void *nc_handle = NULL;
|
||||||
|
+ int nfds, n;
|
||||||
|
+
|
||||||
|
+ if ((nfds = sd_listen_fds(0)) < 0) {
|
||||||
|
+ syslog(LOG_ERR, "failed to acquire systemd sockets: %s", strerror(-nfds));
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+ if (nfds >= 16) {
|
||||||
|
+ syslog(LOG_ERR, "too many sockets passed by systemd (%u)", nfds);
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ for (n = 0; n < nfds; ++n) {
|
||||||
|
+ struct netconfig *nconf;
|
||||||
|
+ struct __rpc_sockinfo si;
|
||||||
|
+ int fd;
|
||||||
|
+
|
||||||
|
+ fd = SD_LISTEN_FDS_START + n;
|
||||||
|
+
|
||||||
|
+ if (!__rpc_fd2sockinfo(fd, &si)) {
|
||||||
|
+ syslog(LOG_ERR, "cannot get socket information for fd %d", fd);
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* Now find the netconfig entry matching this transport */
|
||||||
|
+ if ((nconf = sockinfo2nconf(&nc_handle, &si)) == NULL) {
|
||||||
|
+ syslog(LOG_ERR, "not netconfig for socket fd %d", fd);
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (rpcbind_init_endpoint(nconf, NULL, fd) <= 0) {
|
||||||
|
+ syslog(LOG_ERR, "unable to create transport for socket fd %d", fd);
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (nc_handle)
|
||||||
|
+ endnetconfig(nc_handle);
|
||||||
|
+}
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
+static void
|
||||||
|
rbllist_add(rpcprog_t prog, rpcvers_t vers, struct netconfig *nconf,
|
||||||
|
struct netbuf *addr)
|
||||||
|
{
|
||||||
|
diff --git a/systemd/.gitignore b/systemd/.gitignore
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..b7b4561
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/systemd/.gitignore
|
||||||
|
@@ -0,0 +1 @@
|
||||||
|
+rpcbind.service
|
||||||
|
diff --git a/systemd/rpcbind.service.in b/systemd/rpcbind.service.in
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..58ae5de
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/systemd/rpcbind.service.in
|
||||||
|
@@ -0,0 +1,9 @@
|
||||||
|
+[Unit]
|
||||||
|
+Description=RPC Bind
|
||||||
|
+
|
||||||
|
+[Service]
|
||||||
|
+ExecStart=@bindir@/rpcbind -w -f
|
||||||
|
+
|
||||||
|
+[Install]
|
||||||
|
+WantedBy=multi-user.target
|
||||||
|
+Also=rpcbind.socket
|
||||||
|
diff --git a/systemd/rpcbind.socket b/systemd/rpcbind.socket
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..ad5fd62
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/systemd/rpcbind.socket
|
||||||
|
@@ -0,0 +1,12 @@
|
||||||
|
+[Unit]
|
||||||
|
+Description=RPCbind Server Activation Socket
|
||||||
|
+Wants=rpcbind.target
|
||||||
|
+Before=rpcbind.target
|
||||||
|
+
|
||||||
|
+[Socket]
|
||||||
|
+ListenStream=/var/run/rpcbind.sock
|
||||||
|
+ListenStream=111
|
||||||
|
+ListenDatagram=111
|
||||||
|
+
|
||||||
|
+[Install]
|
||||||
|
+WantedBy=sockets.target
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
@ -1,6 +1,8 @@
|
|||||||
|
From 994e57f91c58e9e88c9f793e948e8d3af6ff4528 Mon Sep 17 00:00:00 2001
|
||||||
From: Jeff Mahoney <jeffm@suse.com>
|
From: Jeff Mahoney <jeffm@suse.com>
|
||||||
Subject: socket-activation: Fix rpcbind.service to use separate sockets
|
Date: Tue, 20 Aug 2013 15:20:13 +0200
|
||||||
References: bnc#757909
|
Subject: [PATCH 11/13] socket-activation: Fix rpcbind.service to use separate
|
||||||
|
sockets
|
||||||
|
|
||||||
systemd will, by default, pass a socket that provides both IPv4 and
|
systemd will, by default, pass a socket that provides both IPv4 and
|
||||||
IPv6 services. RPC netconfig requires that sockets be either IPv4
|
IPv6 services. RPC netconfig requires that sockets be either IPv4
|
||||||
@ -11,15 +13,14 @@ References: bnc#757909
|
|||||||
|
|
||||||
Signed-off-by: Jeff Mahoney <jeffm@suse.com>
|
Signed-off-by: Jeff Mahoney <jeffm@suse.com>
|
||||||
---
|
---
|
||||||
|
src/rpcbind.c | 29 +++++++++++++++++++++++++++++
|
||||||
|
systemd/rpcbind.socket | 11 ++++++++---
|
||||||
|
2 files changed, 37 insertions(+), 3 deletions(-)
|
||||||
|
|
||||||
src/rpcbind.c | 32 +++++++++++++++++++++++++++++++-
|
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
||||||
systemd/rpcbind.socket | 9 +++++++--
|
index 32e6deb..d2b25fa 100644
|
||||||
2 files changed, 38 insertions(+), 3 deletions(-)
|
--- a/src/rpcbind.c
|
||||||
|
+++ b/src/rpcbind.c
|
||||||
Index: rpcbind-0.2.0_git201103171419/src/rpcbind.c
|
|
||||||
===================================================================
|
|
||||||
--- rpcbind-0.2.0_git201103171419.orig/src/rpcbind.c
|
|
||||||
+++ rpcbind-0.2.0_git201103171419/src/rpcbind.c
|
|
||||||
@@ -50,6 +50,7 @@
|
@@ -50,6 +50,7 @@
|
||||||
#include <sys/file.h>
|
#include <sys/file.h>
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
@ -28,7 +29,7 @@ Index: rpcbind-0.2.0_git201103171419/src/rpcbind.c
|
|||||||
#include <rpc/rpc.h>
|
#include <rpc/rpc.h>
|
||||||
#include <rpc/rpc_com.h>
|
#include <rpc/rpc_com.h>
|
||||||
#ifdef PORTMAP
|
#ifdef PORTMAP
|
||||||
@@ -263,6 +264,32 @@ main(int argc, char *argv[])
|
@@ -561,6 +562,31 @@ rpcbind_register_transport(struct netconfig *nconf, SVCXPRT *xprt, struct netbuf
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -44,9 +45,8 @@ Index: rpcbind-0.2.0_git201103171419/src/rpcbind.c
|
|||||||
+ socklen_t len = sizeof(opt);
|
+ socklen_t len = sizeof(opt);
|
||||||
+
|
+
|
||||||
+ if (getsockopt(fd, IPPROTO_IPV6, IPV6_V6ONLY, &opt, &len)) {
|
+ if (getsockopt(fd, IPPROTO_IPV6, IPV6_V6ONLY, &opt, &len)) {
|
||||||
+ syslog(LOG_ERR, "failed to get ipv6 socket opts: %s",
|
+ syslog(LOG_ERR, "failed to get ipv6 socket opts: %m");
|
||||||
+ strerror(errno));
|
+ return -1;
|
||||||
+ return 1;
|
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ if (opt) /* socket is already in V6ONLY mode */
|
+ if (opt) /* socket is already in V6ONLY mode */
|
||||||
@ -54,36 +54,27 @@ Index: rpcbind-0.2.0_git201103171419/src/rpcbind.c
|
|||||||
+
|
+
|
||||||
+ syslog(LOG_ERR, "systemd has passed an IPv4/IPv6 dual-mode socket.");
|
+ syslog(LOG_ERR, "systemd has passed an IPv4/IPv6 dual-mode socket.");
|
||||||
+ syslog(LOG_ERR, "Please fix your systemd config by specifying IPv4 and IPv6 sockets separately and using BindIPv6Only=ipv6-only.");
|
+ syslog(LOG_ERR, "Please fix your systemd config by specifying IPv4 and IPv6 sockets separately and using BindIPv6Only=ipv6-only.");
|
||||||
+ return 1;
|
+ return -1;
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
+/*
|
+/*
|
||||||
* Adds the entry into the rpcbind database.
|
* This will create a server socket for the given netid, bound to the
|
||||||
* If PORTMAP, then for UDP and TCP, it adds the entries for version 2 also
|
* address specified by @hostname
|
||||||
* Returns 0 if succeeds, else fails
|
*
|
||||||
@@ -314,7 +341,7 @@ init_transport(struct netconfig *nconf)
|
@@ -591,6 +617,9 @@ rpcbind_init_endpoint(struct netconfig *nconf, const char *hostname, int fd)
|
||||||
#ifdef SYSTEMD
|
exit(1);
|
||||||
n = sd_listen_fds(0);
|
|
||||||
if (n < 0) {
|
|
||||||
- syslog(LOG_ERR, "failed to acquire systemd scokets: %s", strerror(-n));
|
|
||||||
+ syslog(LOG_ERR, "failed to acquire systemd sockets: %s", strerror(-n));
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -348,6 +375,9 @@ init_transport(struct netconfig *nconf)
|
|
||||||
goto error;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
+ if (sa.sa.sa_family == AF_INET6 && handle_ipv6_socket(fd))
|
+ if (addr.ss_family == AF_INET6 && handle_ipv6_socket(fd))
|
||||||
+ goto error;
|
+ return -1;
|
||||||
+
|
+
|
||||||
/* Copy the address */
|
sockaddr2netbuf((struct sockaddr *) &addr, alen, &taddr.addr);
|
||||||
taddr.addr.maxlen = taddr.addr.len = addrlen;
|
}
|
||||||
taddr.addr.buf = malloc(addrlen);
|
|
||||||
Index: rpcbind-0.2.0_git201103171419/systemd/rpcbind.socket
|
diff --git a/systemd/rpcbind.socket b/systemd/rpcbind.socket
|
||||||
===================================================================
|
index ad5fd62..0b0c1d3 100644
|
||||||
--- rpcbind-0.2.0_git201103171419.orig/systemd/rpcbind.socket
|
--- a/systemd/rpcbind.socket
|
||||||
+++ rpcbind-0.2.0_git201103171419/systemd/rpcbind.socket
|
+++ b/systemd/rpcbind.socket
|
||||||
@@ -4,9 +4,14 @@ Wants=rpcbind.target
|
@@ -4,9 +4,14 @@ Wants=rpcbind.target
|
||||||
Before=rpcbind.target
|
Before=rpcbind.target
|
||||||
|
|
||||||
@ -102,3 +93,6 @@ Index: rpcbind-0.2.0_git201103171419/systemd/rpcbind.socket
|
|||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=sockets.target
|
WantedBy=sockets.target
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
540
0012-When-using-systemd-redirect-syslog-calls-to-the-syst.patch
Normal file
540
0012-When-using-systemd-redirect-syslog-calls-to-the-syst.patch
Normal file
@ -0,0 +1,540 @@
|
|||||||
|
From 2eae383ebb716b27a6ac0aa2c0c2288f92b56b4e Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 20 Aug 2013 15:59:17 +0200
|
||||||
|
Subject: [PATCH 12/13] When using systemd, redirect syslog() calls to the
|
||||||
|
systemd journal
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
Makefile.am | 4 +--
|
||||||
|
configure.ac | 1 +
|
||||||
|
src/check_bound.c | 4 +--
|
||||||
|
src/rpcb_svc.c | 1 -
|
||||||
|
src/rpcb_svc_4.c | 1 -
|
||||||
|
src/rpcb_svc_com.c | 5 ++-
|
||||||
|
src/rpcbind.c | 100 +++++++++++++++++++++++++++++++++++------------------
|
||||||
|
src/rpcbind.h | 3 ++
|
||||||
|
src/security.c | 2 +-
|
||||||
|
src/warmstart.c | 13 ++++---
|
||||||
|
10 files changed, 83 insertions(+), 51 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/Makefile.am b/Makefile.am
|
||||||
|
index df755dd..6f7474f 100644
|
||||||
|
--- a/Makefile.am
|
||||||
|
+++ b/Makefile.am
|
||||||
|
@@ -39,9 +39,9 @@ rpcbind_SOURCES = \
|
||||||
|
rpcbind_LDADD = $(TIRPC_LIBS)
|
||||||
|
|
||||||
|
if SYSTEMD
|
||||||
|
-AM_CPPFLAGS += $(SYSTEMD_CFLAGS) -DSYSTEMD
|
||||||
|
+AM_CPPFLAGS += $(SYSTEMD_CFLAGS) $(SYSTEMD_JOURNAL_CFLAGS) -DSYSTEMD
|
||||||
|
|
||||||
|
-rpcbind_LDADD += $(SYSTEMD_LIBS)
|
||||||
|
+rpcbind_LDADD += $(SYSTEMD_LIBS) $(SYSTEMD_JOURNAL_LIBS)
|
||||||
|
|
||||||
|
systemd/rpcbind.service: systemd/rpcbind.service.in Makefile
|
||||||
|
sed -e 's,@bindir\@,$(bindir),g' \
|
||||||
|
diff --git a/configure.ac b/configure.ac
|
||||||
|
index a94933b..6d91dcd 100644
|
||||||
|
--- a/configure.ac
|
||||||
|
+++ b/configure.ac
|
||||||
|
@@ -36,6 +36,7 @@ AC_ARG_WITH([systemdsystemunitdir],
|
||||||
|
if test "x$with_systemdsystemunitdir" != xno -a "x$with_systemdsystemunitdir" != "x"; then
|
||||||
|
AC_SUBST([systemdsystemunitdir], [$with_systemdsystemunitdir])
|
||||||
|
PKG_CHECK_MODULES([SYSTEMD], [libsystemd-daemon])
|
||||||
|
+ PKG_CHECK_MODULES([SYSTEMD_JOURNAL], [libsystemd-journal])
|
||||||
|
fi
|
||||||
|
AM_CONDITIONAL(SYSTEMD, [test -n "$with_systemdsystemunitdir" -a "x$with_systemdsystemunitdir" != xno ])
|
||||||
|
|
||||||
|
diff --git a/src/check_bound.c b/src/check_bound.c
|
||||||
|
index c70b845..82d84b9 100644
|
||||||
|
--- a/src/check_bound.c
|
||||||
|
+++ b/src/check_bound.c
|
||||||
|
@@ -119,7 +119,7 @@ add_bndlist(struct netconfig *nconf, struct netbuf *baddr /*__unused*/)
|
||||||
|
fdl = malloc(sizeof (struct fdlist));
|
||||||
|
if (fdl == NULL) {
|
||||||
|
freenetconfigent(newnconf);
|
||||||
|
- syslog(LOG_ERR, "no memory!");
|
||||||
|
+ rpcbind_log_error("no memory!");
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
fdl->nconf = newnconf;
|
||||||
|
@@ -179,7 +179,7 @@ mergeaddr(SVCXPRT *xprt, char *netid, char *uaddr, char *saddr)
|
||||||
|
} else {
|
||||||
|
c_uaddr = taddr2uaddr(fdl->nconf, svc_getrpccaller(xprt));
|
||||||
|
if (c_uaddr == NULL) {
|
||||||
|
- syslog(LOG_ERR, "taddr2uaddr failed for %s",
|
||||||
|
+ rpcbind_log_error("taddr2uaddr failed for %s",
|
||||||
|
fdl->nconf->nc_netid);
|
||||||
|
return (NULL);
|
||||||
|
}
|
||||||
|
diff --git a/src/rpcb_svc.c b/src/rpcb_svc.c
|
||||||
|
index e350f85..c26b5be 100644
|
||||||
|
--- a/src/rpcb_svc.c
|
||||||
|
+++ b/src/rpcb_svc.c
|
||||||
|
@@ -45,7 +45,6 @@
|
||||||
|
#include <rpc/rpc.h>
|
||||||
|
#include <rpc/rpcb_prot.h>
|
||||||
|
#include <netconfig.h>
|
||||||
|
-#include <syslog.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
diff --git a/src/rpcb_svc_4.c b/src/rpcb_svc_4.c
|
||||||
|
index 313e6d1..6858095 100644
|
||||||
|
--- a/src/rpcb_svc_4.c
|
||||||
|
+++ b/src/rpcb_svc_4.c
|
||||||
|
@@ -48,7 +48,6 @@
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <netconfig.h>
|
||||||
|
-#include <syslog.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include "rpcbind.h"
|
||||||
|
diff --git a/src/rpcb_svc_com.c b/src/rpcb_svc_com.c
|
||||||
|
index f6bd6bd..1a4ad84 100644
|
||||||
|
--- a/src/rpcb_svc_com.c
|
||||||
|
+++ b/src/rpcb_svc_com.c
|
||||||
|
@@ -50,7 +50,6 @@
|
||||||
|
#include <rpc/svc_dg.h>
|
||||||
|
#include <netconfig.h>
|
||||||
|
#include <errno.h>
|
||||||
|
-#include <syslog.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <time.h>
|
||||||
|
@@ -520,7 +519,7 @@ create_rmtcall_fd(struct netconfig *nconf)
|
||||||
|
}
|
||||||
|
rmt = malloc(sizeof (struct rmtcallfd_list));
|
||||||
|
if (rmt == NULL) {
|
||||||
|
- syslog(LOG_ERR, "create_rmtcall_fd: no memory!");
|
||||||
|
+ rpcbind_log_error("create_rmtcall_fd: no memory!");
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
rmt->xprt = xprt;
|
||||||
|
@@ -1438,7 +1437,7 @@ add_pmaplist(RPCB *arg)
|
||||||
|
*/
|
||||||
|
pml = malloc(sizeof (struct pmaplist));
|
||||||
|
if (pml == NULL) {
|
||||||
|
- (void) syslog(LOG_ERR, "rpcbind: no memory!\n");
|
||||||
|
+ (void) rpcbind_log_error("rpcbind: no memory!\n");
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
pml->pml_map = pmap;
|
||||||
|
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
||||||
|
index d2b25fa..964c2d3 100644
|
||||||
|
--- a/src/rpcbind.c
|
||||||
|
+++ b/src/rpcbind.c
|
||||||
|
@@ -59,18 +59,20 @@
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
#ifdef SYSTEMD
|
||||||
|
#include <systemd/sd-daemon.h>
|
||||||
|
+#include <systemd/sd-journal.h>
|
||||||
|
#endif
|
||||||
|
+#include <syslog.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <netdb.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <netconfig.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
-#include <syslog.h>
|
||||||
|
#include <err.h>
|
||||||
|
#include <pwd.h>
|
||||||
|
#include <grp.h>
|
||||||
|
#include <string.h>
|
||||||
|
+#include <stdarg.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#ifdef HAVE_NSS_H
|
||||||
|
#include <nss.h>
|
||||||
|
@@ -234,19 +236,19 @@ main(int argc, char *argv[])
|
||||||
|
__nss_configure_lookup("passwd", "files");
|
||||||
|
|
||||||
|
if((p = getpwnam(id)) == NULL) {
|
||||||
|
- syslog(LOG_ERR, "cannot get uid of '%s': %m", id);
|
||||||
|
+ rpcbind_log_error("cannot get uid of '%s': %m", id);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if (setgid(p->pw_gid) == -1) {
|
||||||
|
- syslog(LOG_ERR, "setgid to '%s' (%d) failed: %m", id, p->pw_gid);
|
||||||
|
+ rpcbind_log_error("setgid to '%s' (%d) failed: %m", id, p->pw_gid);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if (setgroups(0, NULL) == -1) {
|
||||||
|
- syslog(LOG_ERR, "dropping supplemental groups failed: %m");
|
||||||
|
+ rpcbind_log_error("dropping supplemental groups failed: %m");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if (setuid(p->pw_uid) == -1) {
|
||||||
|
- syslog(LOG_ERR, "setuid to '%s' (%d) failed: %m", id, p->pw_uid);
|
||||||
|
+ rpcbind_log_error("setuid to '%s' (%d) failed: %m", id, p->pw_uid);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -260,7 +262,7 @@ main(int argc, char *argv[])
|
||||||
|
network_init();
|
||||||
|
|
||||||
|
my_svc_run();
|
||||||
|
- syslog(LOG_ERR, "svc_run returned unexpectedly");
|
||||||
|
+ rpcbind_log_error("svc_run returned unexpectedly");
|
||||||
|
rpcbind_abort();
|
||||||
|
/* NOTREACHED */
|
||||||
|
|
||||||
|
@@ -277,7 +279,7 @@ sockaddr2netbuf(const struct sockaddr *sa, socklen_t alen, struct netbuf *abuf)
|
||||||
|
abuf->buf = malloc(alen);
|
||||||
|
|
||||||
|
if (abuf->buf == NULL) {
|
||||||
|
- syslog(LOG_ERR, "not enough memory for address buffer (%u bytes)", alen);
|
||||||
|
+ rpcbind_log_error("not enough memory for address buffer (%u bytes)", alen);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -295,7 +297,7 @@ do_hostname_lookup(struct netconfig *nconf, const char *hostname, struct netbuf
|
||||||
|
int aicode;
|
||||||
|
|
||||||
|
if (!__rpc_nconf2sockinfo(nconf, &si)) {
|
||||||
|
- syslog(LOG_ERR, "cannot get sockinfo for %s", nconf->nc_netid);
|
||||||
|
+ rpcbind_log_error("cannot get sockinfo for %s", nconf->nc_netid);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -334,7 +336,7 @@ do_hostname_lookup(struct netconfig *nconf, const char *hostname, struct netbuf
|
||||||
|
|
||||||
|
if ((aicode = getaddrinfo(hostname, servname, &hints, &res)) != 0) {
|
||||||
|
if ((aicode = getaddrinfo(hostname, "portmapper", &hints, &res)) != 0) {
|
||||||
|
- syslog(LOG_ERR,
|
||||||
|
+ rpcbind_log_error(
|
||||||
|
"cannot get %s address for %s: %s",
|
||||||
|
nconf->nc_netid,
|
||||||
|
hostname? hostname : "*",
|
||||||
|
@@ -389,7 +391,7 @@ create_transport_socket(struct netconfig *nconf, const char *hostname, struct ne
|
||||||
|
* XXX - using RPC library internal functions.
|
||||||
|
*/
|
||||||
|
if ((fd = __rpc_nconf2fd(nconf)) < 0) {
|
||||||
|
- syslog(LOG_ERR, "cannot create socket for %s", nconf->nc_netid);
|
||||||
|
+ rpcbind_log_error("cannot create socket for %s", nconf->nc_netid);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -400,14 +402,14 @@ create_transport_socket(struct netconfig *nconf, const char *hostname, struct ne
|
||||||
|
* This allows us to restart the server even if there are
|
||||||
|
* TCP sockets loitering around in TIME_WAIT */
|
||||||
|
if (setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on)) != 0) {
|
||||||
|
- syslog(LOG_ERR, "cannot set SO_REUSEADDR on %s", nconf->nc_netid);
|
||||||
|
+ rpcbind_log_error("cannot set SO_REUSEADDR on %s", nconf->nc_netid);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
oldmask = umask(S_IXUSR|S_IXGRP|S_IXOTH);
|
||||||
|
if (bind(fd, (struct sockaddr *) abuf->buf, abuf->len) != 0) {
|
||||||
|
- syslog(LOG_ERR, "cannot bind %s on %s: %m",
|
||||||
|
+ rpcbind_log_error("cannot bind %s on %s: %m",
|
||||||
|
hostname? hostname : "*",
|
||||||
|
nconf->nc_netid);
|
||||||
|
(void) umask(oldmask);
|
||||||
|
@@ -417,7 +419,7 @@ create_transport_socket(struct netconfig *nconf, const char *hostname, struct ne
|
||||||
|
|
||||||
|
if (nconf->nc_semantics != NC_TPI_CLTS) {
|
||||||
|
if (listen(fd, SOMAXCONN) < 0) {
|
||||||
|
- syslog(LOG_ERR, "unable to listen on %s socket: %m",
|
||||||
|
+ rpcbind_log_error("unable to listen on %s socket: %m",
|
||||||
|
nconf->nc_netid);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
@@ -465,7 +467,7 @@ rpcbind_register_transport(struct netconfig *nconf, SVCXPRT *xprt, struct netbuf
|
||||||
|
|
||||||
|
pml = malloc(sizeof (struct pmaplist));
|
||||||
|
if (pml == NULL) {
|
||||||
|
- syslog(LOG_ERR, "no memory!");
|
||||||
|
+ rpcbind_log_error("no memory!");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
pml->pml_map.pm_prog = PMAPPROG;
|
||||||
|
@@ -487,7 +489,7 @@ rpcbind_register_transport(struct netconfig *nconf, SVCXPRT *xprt, struct netbuf
|
||||||
|
/* Add version 3 information */
|
||||||
|
pml = malloc(sizeof (struct pmaplist));
|
||||||
|
if (pml == NULL) {
|
||||||
|
- syslog(LOG_ERR, "no memory!");
|
||||||
|
+ rpcbind_log_error("no memory!");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
pml->pml_map = list_pml->pml_map;
|
||||||
|
@@ -498,7 +500,7 @@ rpcbind_register_transport(struct netconfig *nconf, SVCXPRT *xprt, struct netbuf
|
||||||
|
/* Add version 4 information */
|
||||||
|
pml = malloc (sizeof (struct pmaplist));
|
||||||
|
if (pml == NULL) {
|
||||||
|
- syslog(LOG_ERR, "no memory!");
|
||||||
|
+ rpcbind_log_error("no memory!");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
pml->pml_map = list_pml->pml_map;
|
||||||
|
@@ -517,7 +519,7 @@ rpcbind_register_transport(struct netconfig *nconf, SVCXPRT *xprt, struct netbuf
|
||||||
|
* non-root users. */
|
||||||
|
if (si.si_af == AF_INET || si.si_af == AF_LOCAL) {
|
||||||
|
if (!svc_register(xprt, PMAPPROG, PMAPVERS, pmap_service, 0)) {
|
||||||
|
- syslog(LOG_ERR, "could not register on %s",
|
||||||
|
+ rpcbind_log_error("could not register on %s",
|
||||||
|
nconf->nc_netid);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@@ -526,7 +528,7 @@ rpcbind_register_transport(struct netconfig *nconf, SVCXPRT *xprt, struct netbuf
|
||||||
|
|
||||||
|
/* version 3 registration */
|
||||||
|
if (!svc_reg(xprt, RPCBPROG, RPCBVERS, rpcb_service_3, NULL)) {
|
||||||
|
- syslog(LOG_ERR, "could not register %s version 3",
|
||||||
|
+ rpcbind_log_error("could not register %s version 3",
|
||||||
|
nconf->nc_netid);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@@ -534,7 +536,7 @@ rpcbind_register_transport(struct netconfig *nconf, SVCXPRT *xprt, struct netbuf
|
||||||
|
|
||||||
|
/* version 4 registration */
|
||||||
|
if (!svc_reg(xprt, RPCBPROG, RPCBVERS4, rpcb_service_4, NULL)) {
|
||||||
|
- syslog(LOG_ERR, "could not register %s version 4",
|
||||||
|
+ rpcbind_log_error("could not register %s version 4",
|
||||||
|
nconf->nc_netid);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@@ -574,15 +576,15 @@ handle_ipv6_socket(int fd)
|
||||||
|
socklen_t len = sizeof(opt);
|
||||||
|
|
||||||
|
if (getsockopt(fd, IPPROTO_IPV6, IPV6_V6ONLY, &opt, &len)) {
|
||||||
|
- syslog(LOG_ERR, "failed to get ipv6 socket opts: %m");
|
||||||
|
+ rpcbind_log_error("failed to get ipv6 socket opts: %m");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (opt) /* socket is already in V6ONLY mode */
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
- syslog(LOG_ERR, "systemd has passed an IPv4/IPv6 dual-mode socket.");
|
||||||
|
- syslog(LOG_ERR, "Please fix your systemd config by specifying IPv4 and IPv6 sockets separately and using BindIPv6Only=ipv6-only.");
|
||||||
|
+ rpcbind_log_error("systemd has passed an IPv4/IPv6 dual-mode socket.");
|
||||||
|
+ rpcbind_log_error("Please fix your systemd config by specifying IPv4 and IPv6 sockets separately and using BindIPv6Only=ipv6-only.");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -613,7 +615,7 @@ rpcbind_init_endpoint(struct netconfig *nconf, const char *hostname, int fd)
|
||||||
|
socklen_t alen = sizeof(addr);
|
||||||
|
|
||||||
|
if (getsockname(fd, (struct sockaddr *) &addr, &alen) < 0) {
|
||||||
|
- syslog(LOG_ERR, "cannot get address for socket fd %d", fd);
|
||||||
|
+ rpcbind_log_error("cannot get address for socket fd %d", fd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -625,7 +627,7 @@ rpcbind_init_endpoint(struct netconfig *nconf, const char *hostname, int fd)
|
||||||
|
|
||||||
|
my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr, RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
||||||
|
if (my_xprt == (SVCXPRT *)NULL) {
|
||||||
|
- syslog(LOG_ERR, "%s: could not create service", nconf->nc_netid);
|
||||||
|
+ rpcbind_log_error("%s: could not create service", nconf->nc_netid);
|
||||||
|
close(fd);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@@ -667,7 +669,7 @@ init_transport(struct netconfig *nconf)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (!__rpc_nconf2sockinfo(nconf, &si)) {
|
||||||
|
- syslog(LOG_ERR, "cannot get information for %s",
|
||||||
|
+ rpcbind_log_error("cannot get information for %s",
|
||||||
|
nconf->nc_netid);
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
@@ -746,7 +748,7 @@ init_transports_daemon(void)
|
||||||
|
|
||||||
|
nc_handle = setnetconfig(); /* open netconfig file */
|
||||||
|
if (nc_handle == NULL) {
|
||||||
|
- syslog(LOG_ERR, "could not read /etc/netconfig");
|
||||||
|
+ rpcbind_log_error("could not read /etc/netconfig");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -754,7 +756,7 @@ init_transports_daemon(void)
|
||||||
|
if (nconf == NULL)
|
||||||
|
nconf = getnetconfigent("unix");
|
||||||
|
if (nconf == NULL) {
|
||||||
|
- syslog(LOG_ERR, "rpcbind: can't find local transport\n");
|
||||||
|
+ rpcbind_log_error("rpcbind: can't find local transport\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -798,11 +800,11 @@ init_transports_systemd()
|
||||||
|
int nfds, n;
|
||||||
|
|
||||||
|
if ((nfds = sd_listen_fds(0)) < 0) {
|
||||||
|
- syslog(LOG_ERR, "failed to acquire systemd sockets: %s", strerror(-nfds));
|
||||||
|
+ rpcbind_log_error("failed to acquire systemd sockets: %s", strerror(-nfds));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if (nfds >= 16) {
|
||||||
|
- syslog(LOG_ERR, "too many sockets passed by systemd (%u)", nfds);
|
||||||
|
+ rpcbind_log_error("too many sockets passed by systemd (%u)", nfds);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -814,18 +816,18 @@ init_transports_systemd()
|
||||||
|
fd = SD_LISTEN_FDS_START + n;
|
||||||
|
|
||||||
|
if (!__rpc_fd2sockinfo(fd, &si)) {
|
||||||
|
- syslog(LOG_ERR, "cannot get socket information for fd %d", fd);
|
||||||
|
+ rpcbind_log_error("cannot get socket information for fd %d", fd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Now find the netconfig entry matching this transport */
|
||||||
|
if ((nconf = sockinfo2nconf(&nc_handle, &si)) == NULL) {
|
||||||
|
- syslog(LOG_ERR, "not netconfig for socket fd %d", fd);
|
||||||
|
+ rpcbind_log_error("not netconfig for socket fd %d", fd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (rpcbind_init_endpoint(nconf, NULL, fd) <= 0) {
|
||||||
|
- syslog(LOG_ERR, "unable to create transport for socket fd %d", fd);
|
||||||
|
+ rpcbind_log_error("unable to create transport for socket fd %d", fd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -843,7 +845,7 @@ rbllist_add(rpcprog_t prog, rpcvers_t vers, struct netconfig *nconf,
|
||||||
|
|
||||||
|
rbl = malloc(sizeof (rpcblist));
|
||||||
|
if (rbl == NULL) {
|
||||||
|
- syslog(LOG_ERR, "no memory!");
|
||||||
|
+ rpcbind_log_error("no memory!");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
#ifdef RPCBIND_DEBUG
|
||||||
|
@@ -872,7 +874,7 @@ terminate(int dummy /*__unused*/)
|
||||||
|
unlink(_PATH_RPCBINDSOCK);
|
||||||
|
unlink(RPCBINDDLOCK);
|
||||||
|
#ifdef WARMSTART
|
||||||
|
- syslog(LOG_ERR,
|
||||||
|
+ rpcbind_log_error(
|
||||||
|
"rpcbind terminating on signal. Restart with \"rpcbind -w\"");
|
||||||
|
write_warmstart(); /* Dump yourself */
|
||||||
|
#endif
|
||||||
|
@@ -956,3 +958,33 @@ toggle_verboselog(int dummy /*__unused*/)
|
||||||
|
{
|
||||||
|
verboselog = !verboselog;
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+void
|
||||||
|
+rpcbind_log_error(const char *fmt, ...)
|
||||||
|
+{
|
||||||
|
+ va_list ap;
|
||||||
|
+
|
||||||
|
+ va_start(ap, fmt);
|
||||||
|
+#ifdef SYSTEMD
|
||||||
|
+ if (systemd_activation)
|
||||||
|
+ sd_journal_printv(LOG_ERR, fmt, ap);
|
||||||
|
+ else
|
||||||
|
+#endif
|
||||||
|
+ vsyslog(LOG_ERR, fmt, ap);
|
||||||
|
+ va_end(ap);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+void
|
||||||
|
+rpcbind_log(int severity, const char *fmt, ...)
|
||||||
|
+{
|
||||||
|
+ va_list ap;
|
||||||
|
+
|
||||||
|
+ va_start(ap, fmt);
|
||||||
|
+#ifdef SYSTEMD
|
||||||
|
+ if (systemd_activation)
|
||||||
|
+ sd_journal_printv(severity, fmt, ap);
|
||||||
|
+ else
|
||||||
|
+#endif
|
||||||
|
+ vsyslog(severity, fmt, ap);
|
||||||
|
+ va_end(ap);
|
||||||
|
+}
|
||||||
|
diff --git a/src/rpcbind.h b/src/rpcbind.h
|
||||||
|
index 74f9591..bbdbd35 100644
|
||||||
|
--- a/src/rpcbind.h
|
||||||
|
+++ b/src/rpcbind.h
|
||||||
|
@@ -136,6 +136,9 @@ char *addrmerge(struct netbuf *caller, char *serv_uaddr, char *clnt_uaddr, char
|
||||||
|
void network_init(void);
|
||||||
|
struct sockaddr *local_sa(int);
|
||||||
|
|
||||||
|
+void rpcbind_log_error(const char *, ...);
|
||||||
|
+void rpcbind_log(int, const char *, ...);
|
||||||
|
+
|
||||||
|
/* For different getaddr semantics */
|
||||||
|
#define RPCB_ALLVERS 0
|
||||||
|
#define RPCB_ONEVERS 1
|
||||||
|
diff --git a/src/security.c b/src/security.c
|
||||||
|
index d272f74..3b768c0 100644
|
||||||
|
--- a/src/security.c
|
||||||
|
+++ b/src/security.c
|
||||||
|
@@ -274,7 +274,7 @@ logit(int severity, struct sockaddr *addr, rpcproc_t procnum, rpcprog_t prognum,
|
||||||
|
}
|
||||||
|
getnameinfo(addr,size , fromname, sizeof fromname, NULL, 0, NI_NUMERICHOST);
|
||||||
|
}
|
||||||
|
- syslog(severity, "connect from %s to %s(%s)%s",
|
||||||
|
+ rpcbind_log(severity, "connect from %s to %s(%s)%s",
|
||||||
|
fromname, procname, progname, text);
|
||||||
|
_exit(0);
|
||||||
|
}
|
||||||
|
diff --git a/src/warmstart.c b/src/warmstart.c
|
||||||
|
index d1bb971..16eed3e 100644
|
||||||
|
--- a/src/warmstart.c
|
||||||
|
+++ b/src/warmstart.c
|
||||||
|
@@ -42,7 +42,6 @@
|
||||||
|
#include <netinet/in.h>
|
||||||
|
#include <rpc/pmap_prot.h>
|
||||||
|
#endif
|
||||||
|
-#include <syslog.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
|
@@ -77,9 +76,9 @@ write_struct(char *filename, xdrproc_t structproc, void *list)
|
||||||
|
close(i);
|
||||||
|
fp = fopen(filename, "w");
|
||||||
|
if (fp == NULL) {
|
||||||
|
- syslog(LOG_ERR,
|
||||||
|
+ rpcbind_log_error(
|
||||||
|
"cannot open file = %s for writing", filename);
|
||||||
|
- syslog(LOG_ERR, "cannot save any registration");
|
||||||
|
+ rpcbind_log_error("cannot save any registration");
|
||||||
|
return (FALSE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -87,7 +86,7 @@ write_struct(char *filename, xdrproc_t structproc, void *list)
|
||||||
|
xdrstdio_create(&xdrs, fp, XDR_ENCODE);
|
||||||
|
|
||||||
|
if (structproc(&xdrs, list) == FALSE) {
|
||||||
|
- syslog(LOG_ERR, "xdr_%s: failed", filename);
|
||||||
|
+ rpcbind_log_error("xdr_%s: failed", filename);
|
||||||
|
fclose(fp);
|
||||||
|
return (FALSE);
|
||||||
|
}
|
||||||
|
@@ -106,7 +105,7 @@ read_struct(char *filename, xdrproc_t structproc, void *list)
|
||||||
|
fprintf(stderr, "rpcbind: using '%s' startup file\n", filename);
|
||||||
|
|
||||||
|
if ((fp = fopen(filename, "r")) == NULL) {
|
||||||
|
- syslog(LOG_ERR,
|
||||||
|
+ rpcbind_log_error(
|
||||||
|
"Cannot open '%s' file for reading, errno %d (%s)",
|
||||||
|
filename, errno, strerror(errno));
|
||||||
|
goto error;
|
||||||
|
@@ -122,14 +121,14 @@ read_struct(char *filename, xdrproc_t structproc, void *list)
|
||||||
|
|
||||||
|
fclose(fp);
|
||||||
|
if (unlink(filename) < 0) {
|
||||||
|
- syslog(LOG_ERR, "Cannot unlink '%s', errno %d (%s)",
|
||||||
|
+ rpcbind_log_error("Cannot unlink '%s', errno %d (%s)",
|
||||||
|
filename, errno, strerror(errno));
|
||||||
|
}
|
||||||
|
return (TRUE);
|
||||||
|
|
||||||
|
error:
|
||||||
|
if (errno != ENOENT && unlink(filename) < 0) {
|
||||||
|
- syslog(LOG_ERR, "Cannot unlink '%s', errno %d (%s)",
|
||||||
|
+ rpcbind_log_error("Cannot unlink '%s', errno %d (%s)",
|
||||||
|
filename, errno, strerror(errno));
|
||||||
|
}
|
||||||
|
if (debugging)
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
@ -0,0 +1,43 @@
|
|||||||
|
From 417e4dc9a33711843a36c700fbc3ce1d7a823a0d Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 20 Aug 2013 16:01:59 +0200
|
||||||
|
Subject: [PATCH 13/13] When using systemd activation, make rpcbind notify
|
||||||
|
system when ready to service requests
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
src/rpcbind.c | 5 ++++-
|
||||||
|
systemd/rpcbind.service.in | 1 +
|
||||||
|
2 files changed, 5 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
||||||
|
index 964c2d3..7fa6baf 100644
|
||||||
|
--- a/src/rpcbind.c
|
||||||
|
+++ b/src/rpcbind.c
|
||||||
|
@@ -260,7 +260,10 @@ main(int argc, char *argv[])
|
||||||
|
#endif
|
||||||
|
|
||||||
|
network_init();
|
||||||
|
-
|
||||||
|
+#ifdef SYSTEMD
|
||||||
|
+ if (systemd_activation)
|
||||||
|
+ sd_notify(0, "READY=1");
|
||||||
|
+#endif
|
||||||
|
my_svc_run();
|
||||||
|
rpcbind_log_error("svc_run returned unexpectedly");
|
||||||
|
rpcbind_abort();
|
||||||
|
diff --git a/systemd/rpcbind.service.in b/systemd/rpcbind.service.in
|
||||||
|
index 58ae5de..527d07b 100644
|
||||||
|
--- a/systemd/rpcbind.service.in
|
||||||
|
+++ b/systemd/rpcbind.service.in
|
||||||
|
@@ -2,6 +2,7 @@
|
||||||
|
Description=RPC Bind
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
+Type=notify
|
||||||
|
ExecStart=@bindir@/rpcbind -w -f
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
40
0014-Notify-systemd-unconditionally.patch
Normal file
40
0014-Notify-systemd-unconditionally.patch
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
From 95d8dc18699638313a2b9bd3dcd3b84eaed432d8 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Fri, 10 Jan 2014 11:29:40 +0100
|
||||||
|
Subject: [PATCH 14/14] Notify systemd unconditionally
|
||||||
|
|
||||||
|
rpcbind may be started from systemd with or without socket activation.
|
||||||
|
However, in both cases systemd would expect to be notified of successful
|
||||||
|
startup.
|
||||||
|
|
||||||
|
If we're started from the command line, calling sd_notify doesn't do
|
||||||
|
any harm either; it will just silently fail.
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
src/rpcbind.c | 8 ++++++--
|
||||||
|
1 file changed, 6 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
||||||
|
index 7fa6baf..8df2950 100644
|
||||||
|
--- a/src/rpcbind.c
|
||||||
|
+++ b/src/rpcbind.c
|
||||||
|
@@ -260,9 +260,13 @@ main(int argc, char *argv[])
|
||||||
|
#endif
|
||||||
|
|
||||||
|
network_init();
|
||||||
|
+
|
||||||
|
#ifdef SYSTEMD
|
||||||
|
- if (systemd_activation)
|
||||||
|
- sd_notify(0, "READY=1");
|
||||||
|
+ /* Try to notify system of successful startup, regardless of whether we
|
||||||
|
+ * used systemd socket activation or not. When started from the command
|
||||||
|
+ * line, this should not hurt either.
|
||||||
|
+ */
|
||||||
|
+ rpcbind_log_error("sd_notify returns %d\n", sd_notify(0, "READY=1"));
|
||||||
|
#endif
|
||||||
|
my_svc_run();
|
||||||
|
rpcbind_log_error("svc_run returned unexpectedly");
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
@ -0,0 +1,27 @@
|
|||||||
|
From 565692c3c88c6e94f31fb511c374d5a9f3c31075 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 14 Jan 2014 16:19:04 +0100
|
||||||
|
Subject: [PATCH 15/15] Pull the sysconfig file into rpcbind.service and use
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
systemd/rpcbind.service.in | 3 ++-
|
||||||
|
1 file changed, 2 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/systemd/rpcbind.service.in b/systemd/rpcbind.service.in
|
||||||
|
index 527d07b..1f5b596 100644
|
||||||
|
--- a/systemd/rpcbind.service.in
|
||||||
|
+++ b/systemd/rpcbind.service.in
|
||||||
|
@@ -3,7 +3,8 @@ Description=RPC Bind
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=notify
|
||||||
|
-ExecStart=@bindir@/rpcbind -w -f
|
||||||
|
+EnvironmentFile=-/etc/sysconfig/rpcbind
|
||||||
|
+ExecStart=@bindir@/rpcbind $RPCBIND_OPTIONS -w -f
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
30
0016-configure-check-for-nss.h.patch
Normal file
30
0016-configure-check-for-nss.h.patch
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
From 0be5e1d603226b3226e4204f67471788eacf475c Mon Sep 17 00:00:00 2001
|
||||||
|
From: Olaf Kirch <okir@suse.de>
|
||||||
|
Date: Tue, 14 Jan 2014 16:40:55 +0100
|
||||||
|
Subject: [PATCH 17/17] configure: check for <nss.h>
|
||||||
|
|
||||||
|
There's code in rpcbind that tries to configure nss lookups so that it
|
||||||
|
avoids NIS when resolving user names or service names. Unfortunately, this
|
||||||
|
code is turned into a no-op unless HAVE_NSS_H is defined. Which it is not
|
||||||
|
unless the configure script actually checks for it.
|
||||||
|
|
||||||
|
Signed-off-by: Olaf Kirch <okir@suse.de>
|
||||||
|
---
|
||||||
|
configure.ac | 1 +
|
||||||
|
1 file changed, 1 insertion(+)
|
||||||
|
|
||||||
|
diff --git a/configure.ac b/configure.ac
|
||||||
|
index 6d91dcd..8cdd08f 100644
|
||||||
|
--- a/configure.ac
|
||||||
|
+++ b/configure.ac
|
||||||
|
@@ -40,6 +40,7 @@ AC_ARG_WITH([systemdsystemunitdir],
|
||||||
|
fi
|
||||||
|
AM_CONDITIONAL(SYSTEMD, [test -n "$with_systemdsystemunitdir" -a "x$with_systemdsystemunitdir" != xno ])
|
||||||
|
|
||||||
|
+AC_CHECK_HEADERS(nss.h)
|
||||||
|
|
||||||
|
AS_IF([test x$enable_libwrap = xyes], [
|
||||||
|
AC_CHECK_LIB([wrap], [hosts_access], ,
|
||||||
|
--
|
||||||
|
1.7.12.4
|
||||||
|
|
@ -1,13 +0,0 @@
|
|||||||
Index: rpcbind-0.2.0_git201103171419/src/rpcbind.c
|
|
||||||
===================================================================
|
|
||||||
--- rpcbind-0.2.0_git201103171419.orig/src/rpcbind.c
|
|
||||||
+++ rpcbind-0.2.0_git201103171419/src/rpcbind.c
|
|
||||||
@@ -93,7 +93,7 @@ char *rpcbinduser = NULL;
|
|
||||||
/* who to suid to if -s is given */
|
|
||||||
#define RUN_AS "daemon"
|
|
||||||
|
|
||||||
-#define RPCBINDDLOCK "/var/run/rpcbind.lock"
|
|
||||||
+#define RPCBINDDLOCK "/run/rpcbind.lock"
|
|
||||||
|
|
||||||
int runasdaemon = 0;
|
|
||||||
int insecure = 0;
|
|
@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:dd1363a8537a5839814d9a013a1b014353752e2d63dcb94c33d662dfae4e94f7
|
|
||||||
size 49419
|
|
3
rpcbind-0.2.1_git1b0fdf5.tar.bz2
Normal file
3
rpcbind-0.2.1_git1b0fdf5.tar.bz2
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:9fde689ddaf775c092a10012281fa4b8fcbbcee77ccf1b0784feed45c523b604
|
||||||
|
size 49282
|
@ -1,520 +0,0 @@
|
|||||||
--- src/check_bound.c.orig
|
|
||||||
+++ src/check_bound.c
|
|
||||||
@@ -52,7 +52,6 @@ static char sccsid[] = "@(#)check_bound.
|
|
||||||
#include <rpc/rpc.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <netconfig.h>
|
|
||||||
-#include <syslog.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
@@ -119,7 +118,7 @@ add_bndlist(struct netconfig *nconf, str
|
|
||||||
fdl = malloc(sizeof (struct fdlist));
|
|
||||||
if (fdl == NULL) {
|
|
||||||
freenetconfigent(newnconf);
|
|
||||||
- syslog(LOG_ERR, "no memory!");
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "no memory!");
|
|
||||||
return (-1);
|
|
||||||
}
|
|
||||||
fdl->nconf = newnconf;
|
|
||||||
@@ -179,7 +178,7 @@ mergeaddr(SVCXPRT *xprt, char *netid, ch
|
|
||||||
} else {
|
|
||||||
c_uaddr = taddr2uaddr(fdl->nconf, svc_getrpccaller(xprt));
|
|
||||||
if (c_uaddr == NULL) {
|
|
||||||
- syslog(LOG_ERR, "taddr2uaddr failed for %s",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "taddr2uaddr failed for %s",
|
|
||||||
fdl->nconf->nc_netid);
|
|
||||||
return (NULL);
|
|
||||||
}
|
|
||||||
--- src/rpcb_svc.c.orig
|
|
||||||
+++ src/rpcb_svc.c
|
|
||||||
@@ -45,7 +45,6 @@
|
|
||||||
#include <rpc/rpc.h>
|
|
||||||
#include <rpc/rpcb_prot.h>
|
|
||||||
#include <netconfig.h>
|
|
||||||
-#include <syslog.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
--- src/rpcb_svc_4.c.orig
|
|
||||||
+++ src/rpcb_svc_4.c
|
|
||||||
@@ -48,7 +48,6 @@
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <netconfig.h>
|
|
||||||
-#include <syslog.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include "rpcbind.h"
|
|
||||||
--- src/rpcb_svc_com.c.orig
|
|
||||||
+++ src/rpcb_svc_com.c
|
|
||||||
@@ -50,7 +50,6 @@
|
|
||||||
#include <rpc/svc_dg.h>
|
|
||||||
#include <netconfig.h>
|
|
||||||
#include <errno.h>
|
|
||||||
-#include <syslog.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <time.h>
|
|
||||||
@@ -520,7 +519,7 @@ create_rmtcall_fd(struct netconfig *ncon
|
|
||||||
}
|
|
||||||
rmt = malloc(sizeof (struct rmtcallfd_list));
|
|
||||||
if (rmt == NULL) {
|
|
||||||
- syslog(LOG_ERR, "create_rmtcall_fd: no memory!");
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "create_rmtcall_fd: no memory!");
|
|
||||||
return (-1);
|
|
||||||
}
|
|
||||||
rmt->xprt = xprt;
|
|
||||||
@@ -1433,7 +1432,7 @@ add_pmaplist(RPCB *arg)
|
|
||||||
*/
|
|
||||||
pml = malloc(sizeof (struct pmaplist));
|
|
||||||
if (pml == NULL) {
|
|
||||||
- (void) syslog(LOG_ERR, "rpcbind: no memory!\n");
|
|
||||||
+ (void) rpcbind_syslog(LOG_ERR, "rpcbind: no memory!\n");
|
|
||||||
return (1);
|
|
||||||
}
|
|
||||||
pml->pml_map = pmap;
|
|
||||||
--- src/rpcbind.c.orig
|
|
||||||
+++ src/rpcbind.c
|
|
||||||
@@ -66,7 +66,6 @@
|
|
||||||
#include <netconfig.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
-#include <syslog.h>
|
|
||||||
#include <err.h>
|
|
||||||
#include <pwd.h>
|
|
||||||
#include <string.h>
|
|
||||||
@@ -169,7 +168,7 @@ main(int argc, char *argv[])
|
|
||||||
|
|
||||||
nc_handle = setnetconfig(); /* open netconfig file */
|
|
||||||
if (nc_handle == NULL) {
|
|
||||||
- syslog(LOG_ERR, "could not read /etc/netconfig");
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "could not read /etc/netconfig");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -177,7 +176,7 @@ main(int argc, char *argv[])
|
|
||||||
if (nconf == NULL)
|
|
||||||
nconf = getnetconfigent("unix");
|
|
||||||
if (nconf == NULL) {
|
|
||||||
- syslog(LOG_ERR, "%s: can't find local transport\n", argv[0]);
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "%s: can't find local transport\n", argv[0]);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -234,15 +233,15 @@ main(int argc, char *argv[])
|
|
||||||
__nss_configure_lookup("passwd", "files");
|
|
||||||
|
|
||||||
if((p = getpwnam(id)) == NULL) {
|
|
||||||
- syslog(LOG_ERR, "cannot get uid of '%s': %m", id);
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "cannot get uid of '%s': %m", id);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
if (setgid(p->pw_gid) == -1) {
|
|
||||||
- syslog(LOG_ERR, "setgid to '%s' (%d) failed: %m", id, p->pw_gid);
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "setgid to '%s' (%d) failed: %m", id, p->pw_gid);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
if (setuid(p->pw_uid) == -1) {
|
|
||||||
- syslog(LOG_ERR, "setuid to '%s' (%d) failed: %m", id, p->pw_uid);
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "setuid to '%s' (%d) failed: %m", id, p->pw_uid);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -256,7 +255,7 @@ main(int argc, char *argv[])
|
|
||||||
network_init();
|
|
||||||
|
|
||||||
my_svc_run();
|
|
||||||
- syslog(LOG_ERR, "svc_run returned unexpectedly");
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "svc_run returned unexpectedly");
|
|
||||||
rpcbind_abort();
|
|
||||||
/* NOTREACHED */
|
|
||||||
|
|
||||||
@@ -276,7 +275,7 @@ handle_ipv6_socket(int fd)
|
|
||||||
socklen_t len = sizeof(opt);
|
|
||||||
|
|
||||||
if (getsockopt(fd, IPPROTO_IPV6, IPV6_V6ONLY, &opt, &len)) {
|
|
||||||
- syslog(LOG_ERR, "failed to get ipv6 socket opts: %s",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "failed to get ipv6 socket opts: %s",
|
|
||||||
strerror(errno));
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
@@ -284,8 +283,8 @@ handle_ipv6_socket(int fd)
|
|
||||||
if (opt) /* socket is already in V6ONLY mode */
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
- syslog(LOG_ERR, "systemd has passed an IPv4/IPv6 dual-mode socket.");
|
|
||||||
- syslog(LOG_ERR, "Please fix your systemd config by specifying IPv4 and IPv6 sockets separately and using BindIPv6Only=ipv6-only.");
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "systemd has passed an IPv4/IPv6 dual-mode socket.");
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "Please fix your systemd config by specifying IPv4 and IPv6 sockets separately and using BindIPv6Only=ipv6-only.");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -333,7 +332,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (!__rpc_nconf2sockinfo(nconf, &si)) {
|
|
||||||
- syslog(LOG_ERR, "cannot get information for %s",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "cannot get information for %s",
|
|
||||||
nconf->nc_netid);
|
|
||||||
return (1);
|
|
||||||
}
|
|
||||||
@@ -341,7 +340,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
#ifdef SYSTEMD
|
|
||||||
n = sd_listen_fds(0);
|
|
||||||
if (n < 0) {
|
|
||||||
- syslog(LOG_ERR, "failed to acquire systemd sockets: %s", strerror(-n));
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "failed to acquire systemd sockets: %s", strerror(-n));
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -360,7 +359,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
socklen_t addrlen = sizeof(sa);
|
|
||||||
|
|
||||||
if (!__rpc_fd2sockinfo(fd, &si_other)) {
|
|
||||||
- syslog(LOG_ERR, "cannot get information for fd %i", fd);
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "cannot get information for fd %i", fd);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -370,7 +369,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (getsockname(fd, &sa.sa, &addrlen) < 0) {
|
|
||||||
- syslog(LOG_ERR, "failed to query socket name: %s",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "failed to query socket name: %s",
|
|
||||||
strerror(errno));
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
@@ -382,7 +381,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
taddr.addr.maxlen = taddr.addr.len = addrlen;
|
|
||||||
taddr.addr.buf = malloc(addrlen);
|
|
||||||
if (taddr.addr.buf == NULL) {
|
|
||||||
- syslog(LOG_ERR,
|
|
||||||
+ rpcbind_syslog(LOG_ERR,
|
|
||||||
"cannot allocate memory for %s address",
|
|
||||||
nconf->nc_netid);
|
|
||||||
goto error;
|
|
||||||
@@ -392,7 +391,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr,
|
|
||||||
RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
|
||||||
if (my_xprt == (SVCXPRT *)NULL) {
|
|
||||||
- syslog(LOG_ERR, "%s: could not create service",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "%s: could not create service",
|
|
||||||
nconf->nc_netid);
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
@@ -419,7 +418,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
*/
|
|
||||||
if (nconf->nc_semantics != NC_TPI_CLTS) {
|
|
||||||
if ((fd = __rpc_nconf2fd(nconf)) < 0) {
|
|
||||||
- syslog(LOG_ERR, "cannot create socket for %s",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "cannot create socket for %s",
|
|
||||||
nconf->nc_netid);
|
|
||||||
return (1);
|
|
||||||
}
|
|
||||||
@@ -471,7 +470,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
* XXX - using RPC library internal functions.
|
|
||||||
*/
|
|
||||||
if ((fd = __rpc_nconf2fd(nconf)) < 0) {
|
|
||||||
- syslog(LOG_ERR, "cannot create socket for %s",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "cannot create socket for %s",
|
|
||||||
nconf->nc_netid);
|
|
||||||
return (1);
|
|
||||||
}
|
|
||||||
@@ -516,7 +515,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
servname, &hints, &res)) != 0) {
|
|
||||||
if ((aicode = getaddrinfo(hosts[nhostsbak],
|
|
||||||
"portmapper", &hints, &res)) != 0) {
|
|
||||||
- syslog(LOG_ERR,
|
|
||||||
+ rpcbind_syslog(LOG_ERR,
|
|
||||||
"cannot get local address for %s: %s",
|
|
||||||
nconf->nc_netid, gai_strerror(aicode));
|
|
||||||
continue;
|
|
||||||
@@ -526,7 +525,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
sa = (struct sockaddr *)res->ai_addr;
|
|
||||||
oldmask = umask(S_IXUSR|S_IXGRP|S_IXOTH);
|
|
||||||
if (bind(fd, sa, addrlen) != 0) {
|
|
||||||
- syslog(LOG_ERR, "cannot bind %s on %s: %m",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "cannot bind %s on %s: %m",
|
|
||||||
(hosts[nhostsbak] == NULL) ? "*" :
|
|
||||||
hosts[nhostsbak], nconf->nc_netid);
|
|
||||||
if (res != NULL)
|
|
||||||
@@ -540,7 +539,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
taddr.addr.maxlen = taddr.addr.len = addrlen;
|
|
||||||
taddr.addr.buf = malloc(addrlen);
|
|
||||||
if (taddr.addr.buf == NULL) {
|
|
||||||
- syslog(LOG_ERR,
|
|
||||||
+ rpcbind_syslog(LOG_ERR,
|
|
||||||
"cannot allocate memory for %s address",
|
|
||||||
nconf->nc_netid);
|
|
||||||
if (res != NULL)
|
|
||||||
@@ -577,7 +576,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr,
|
|
||||||
RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
|
||||||
if (my_xprt == (SVCXPRT *)NULL) {
|
|
||||||
- syslog(LOG_ERR, "%s: could not create service",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "%s: could not create service",
|
|
||||||
nconf->nc_netid);
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
@@ -590,7 +589,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
if ((aicode = getaddrinfo(NULL, servname, &hints, &res))!= 0) {
|
|
||||||
if ((aicode = getaddrinfo(NULL, "portmapper", &hints, &res))!= 0) {
|
|
||||||
printf("cannot get local address for %s: %s", nconf->nc_netid, gai_strerror(aicode));
|
|
||||||
- syslog(LOG_ERR,
|
|
||||||
+ rpcbind_syslog(LOG_ERR,
|
|
||||||
"cannot get local address for %s: %s",
|
|
||||||
nconf->nc_netid, gai_strerror(aicode));
|
|
||||||
return 1;
|
|
||||||
@@ -603,14 +602,14 @@ init_transport(struct netconfig *nconf)
|
|
||||||
__rpc_fd2sockinfo(fd, &si);
|
|
||||||
if (setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &on,
|
|
||||||
sizeof(on)) != 0) {
|
|
||||||
- syslog(LOG_ERR, "cannot set SO_REUSEADDR on %s",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "cannot set SO_REUSEADDR on %s",
|
|
||||||
nconf->nc_netid);
|
|
||||||
if (res != NULL)
|
|
||||||
freeaddrinfo(res);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
if (bind(fd, sa, addrlen) < 0) {
|
|
||||||
- syslog(LOG_ERR, "cannot bind %s: %m", nconf->nc_netid);
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "cannot bind %s: %m", nconf->nc_netid);
|
|
||||||
if (res != NULL)
|
|
||||||
freeaddrinfo(res);
|
|
||||||
return 1;
|
|
||||||
@@ -621,7 +620,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
taddr.addr.len = taddr.addr.maxlen = addrlen;
|
|
||||||
taddr.addr.buf = malloc(addrlen);
|
|
||||||
if (taddr.addr.buf == NULL) {
|
|
||||||
- syslog(LOG_ERR, "cannot allocate memory for %s address",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "cannot allocate memory for %s address",
|
|
||||||
nconf->nc_netid);
|
|
||||||
if (res != NULL)
|
|
||||||
freeaddrinfo(res);
|
|
||||||
@@ -656,7 +655,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
|
|
||||||
my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr, RPC_MAXDATASIZE, RPC_MAXDATASIZE);
|
|
||||||
if (my_xprt == (SVCXPRT *)NULL) {
|
|
||||||
- syslog(LOG_ERR, "%s: could not create service",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "%s: could not create service",
|
|
||||||
nconf->nc_netid);
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
@@ -673,7 +672,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
|
|
||||||
pml = malloc(sizeof (struct pmaplist));
|
|
||||||
if (pml == NULL) {
|
|
||||||
- syslog(LOG_ERR, "no memory!");
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "no memory!");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
pml->pml_map.pm_prog = PMAPPROG;
|
|
||||||
@@ -695,7 +694,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
/* Add version 3 information */
|
|
||||||
pml = malloc(sizeof (struct pmaplist));
|
|
||||||
if (pml == NULL) {
|
|
||||||
- syslog(LOG_ERR, "no memory!");
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "no memory!");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
pml->pml_map = list_pml->pml_map;
|
|
||||||
@@ -706,7 +705,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
/* Add version 4 information */
|
|
||||||
pml = malloc (sizeof (struct pmaplist));
|
|
||||||
if (pml == NULL) {
|
|
||||||
- syslog(LOG_ERR, "no memory!");
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "no memory!");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
pml->pml_map = list_pml->pml_map;
|
|
||||||
@@ -725,7 +724,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
* non-root users. */
|
|
||||||
if (si.si_af == AF_INET || si.si_af == AF_LOCAL) {
|
|
||||||
if (!svc_register(my_xprt, PMAPPROG, PMAPVERS, pmap_service, 0)) {
|
|
||||||
- syslog(LOG_ERR, "could not register on %s",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "could not register on %s",
|
|
||||||
nconf->nc_netid);
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
@@ -734,7 +733,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
|
|
||||||
/* version 3 registration */
|
|
||||||
if (!svc_reg(my_xprt, RPCBPROG, RPCBVERS, rpcb_service_3, NULL)) {
|
|
||||||
- syslog(LOG_ERR, "could not register %s version 3",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "could not register %s version 3",
|
|
||||||
nconf->nc_netid);
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
@@ -742,7 +741,7 @@ init_transport(struct netconfig *nconf)
|
|
||||||
|
|
||||||
/* version 4 registration */
|
|
||||||
if (!svc_reg(my_xprt, RPCBPROG, RPCBVERS4, rpcb_service_4, NULL)) {
|
|
||||||
- syslog(LOG_ERR, "could not register %s version 4",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "could not register %s version 4",
|
|
||||||
nconf->nc_netid);
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
@@ -797,7 +796,7 @@ rbllist_add(rpcprog_t prog, rpcvers_t ve
|
|
||||||
|
|
||||||
rbl = malloc(sizeof (rpcblist));
|
|
||||||
if (rbl == NULL) {
|
|
||||||
- syslog(LOG_ERR, "no memory!");
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "no memory!");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
#ifdef RPCBIND_DEBUG
|
|
||||||
@@ -827,7 +826,7 @@ terminate(int dummy /*__unused*/)
|
|
||||||
unlink(_PATH_RPCBINDSOCK);
|
|
||||||
unlink(RPCBINDDLOCK);
|
|
||||||
#ifdef WARMSTART
|
|
||||||
- syslog(LOG_ERR,
|
|
||||||
+ rpcbind_syslog(LOG_ERR,
|
|
||||||
"rpcbind terminating on signal. Restart with \"rpcbind -w\"");
|
|
||||||
write_warmstart(); /* Dump yourself */
|
|
||||||
#endif
|
|
||||||
--- src/rpcbind.h.orig
|
|
||||||
+++ src/rpcbind.h
|
|
||||||
@@ -47,6 +47,14 @@
|
|
||||||
#endif
|
|
||||||
#include <rpc/rpcb_prot.h>
|
|
||||||
|
|
||||||
+#include <syslog.h>
|
|
||||||
+#ifdef SYSTEMD
|
|
||||||
+#include <systemd/sd-journal.h>
|
|
||||||
+#define rpcbind_syslog sd_journal_print
|
|
||||||
+#else
|
|
||||||
+#define rpcbind_syslog syslog
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
/*
|
|
||||||
* Stuff for the rmtcall service
|
|
||||||
*/
|
|
||||||
--- src/security.c.orig
|
|
||||||
+++ src/security.c
|
|
||||||
@@ -14,7 +14,6 @@
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
-#include <syslog.h>
|
|
||||||
#include <netdb.h>
|
|
||||||
|
|
||||||
/*
|
|
||||||
@@ -201,7 +200,7 @@ is_localroot(struct netbuf *nbuf)
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
-/* logit - report events of interest via the syslog daemon */
|
|
||||||
+/* logit - report events of interest via the rpcbind_syslog daemon */
|
|
||||||
void
|
|
||||||
logit(int severity, struct sockaddr *addr, rpcproc_t procnum, rpcprog_t prognum,
|
|
||||||
const char *text){
|
|
||||||
@@ -231,7 +230,7 @@ logit(int severity, struct sockaddr *add
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Fork off a process or the portmap daemon might hang while
|
|
||||||
- * getrpcbynumber() or syslog() does its thing.
|
|
||||||
+ * getrpcbynumber() or rpcbind_syslog() does its thing.
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (fork() == 0) {
|
|
||||||
@@ -256,7 +255,7 @@ logit(int severity, struct sockaddr *add
|
|
||||||
} else
|
|
||||||
procname = procmap[procnum];
|
|
||||||
|
|
||||||
- /* Write syslog record. */
|
|
||||||
+ /* Write rpcbind_syslog record. */
|
|
||||||
|
|
||||||
if (addr->sa_family == AF_LOCAL)
|
|
||||||
strcpy(fromname, "local");
|
|
||||||
@@ -274,7 +273,7 @@ logit(int severity, struct sockaddr *add
|
|
||||||
}
|
|
||||||
getnameinfo(addr,size , fromname, sizeof fromname, NULL, 0, NI_NUMERICHOST);
|
|
||||||
}
|
|
||||||
- syslog(severity, "connect from %s to %s(%s)%s",
|
|
||||||
+ rpcbind_syslog(severity, "connect from %s to %s(%s)%s",
|
|
||||||
fromname, procname, progname, text);
|
|
||||||
_exit(0);
|
|
||||||
}
|
|
||||||
--- src/warmstart.c.orig
|
|
||||||
+++ src/warmstart.c
|
|
||||||
@@ -42,7 +42,6 @@
|
|
||||||
#include <netinet/in.h>
|
|
||||||
#include <rpc/pmap_prot.h>
|
|
||||||
#endif
|
|
||||||
-#include <syslog.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <errno.h>
|
|
||||||
|
|
||||||
@@ -77,9 +76,9 @@ write_struct(char *filename, xdrproc_t s
|
|
||||||
close(i);
|
|
||||||
fp = fopen(filename, "w");
|
|
||||||
if (fp == NULL) {
|
|
||||||
- syslog(LOG_ERR,
|
|
||||||
+ rpcbind_syslog(LOG_ERR,
|
|
||||||
"cannot open file = %s for writing", filename);
|
|
||||||
- syslog(LOG_ERR, "cannot save any registration");
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "cannot save any registration");
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -87,7 +86,7 @@ write_struct(char *filename, xdrproc_t s
|
|
||||||
xdrstdio_create(&xdrs, fp, XDR_ENCODE);
|
|
||||||
|
|
||||||
if (structproc(&xdrs, list) == FALSE) {
|
|
||||||
- syslog(LOG_ERR, "xdr_%s: failed", filename);
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "xdr_%s: failed", filename);
|
|
||||||
fclose(fp);
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
@@ -106,7 +105,7 @@ read_struct(char *filename, xdrproc_t st
|
|
||||||
fprintf(stderr, "rpcbind: using '%s' startup file\n", filename);
|
|
||||||
|
|
||||||
if ((fp = fopen(filename, "r")) == NULL) {
|
|
||||||
- syslog(LOG_ERR,
|
|
||||||
+ rpcbind_syslog(LOG_ERR,
|
|
||||||
"Cannot open '%s' file for reading, errno %d (%s)",
|
|
||||||
filename, errno, strerror(errno));
|
|
||||||
goto error;
|
|
||||||
@@ -122,14 +121,14 @@ read_struct(char *filename, xdrproc_t st
|
|
||||||
|
|
||||||
fclose(fp);
|
|
||||||
if (unlink(filename) < 0) {
|
|
||||||
- syslog(LOG_ERR, "Cannot unlink '%s', errno %d (%s)",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "Cannot unlink '%s', errno %d (%s)",
|
|
||||||
filename, errno, strerror(errno));
|
|
||||||
}
|
|
||||||
return (TRUE);
|
|
||||||
|
|
||||||
error:
|
|
||||||
if (errno != ENOENT && unlink(filename) < 0) {
|
|
||||||
- syslog(LOG_ERR, "Cannot unlink '%s', errno %d (%s)",
|
|
||||||
+ rpcbind_syslog(LOG_ERR, "Cannot unlink '%s', errno %d (%s)",
|
|
||||||
filename, errno, strerror(errno));
|
|
||||||
}
|
|
||||||
if (debugging)
|
|
||||||
--- configure.in.orig
|
|
||||||
+++ configure.in
|
|
||||||
@@ -36,6 +36,7 @@ AC_ARG_WITH([systemdsystemunitdir],
|
|
||||||
if test "x$with_systemdsystemunitdir" != xno; then
|
|
||||||
AC_SUBST([systemdsystemunitdir], [$with_systemdsystemunitdir])
|
|
||||||
PKG_CHECK_MODULES([SYSTEMD], [libsystemd-daemon])
|
|
||||||
+ PKG_CHECK_MODULES([SYSTEMD_JOURNAL], [libsystemd-journal])
|
|
||||||
fi
|
|
||||||
AM_CONDITIONAL(SYSTEMD, [test -n "$with_systemdsystemunitdir" -a "x$with_systemdsystemunitdir" != xno ])
|
|
||||||
|
|
||||||
--- Makefile.am.orig
|
|
||||||
+++ Makefile.am
|
|
||||||
@@ -39,9 +39,9 @@ rpcbind_SOURCES = \
|
|
||||||
rpcbind_LDADD = $(TIRPC_LIBS)
|
|
||||||
|
|
||||||
if SYSTEMD
|
|
||||||
-AM_CPPFLAGS += $(SYSTEMD_CFLAGS) -DSYSTEMD
|
|
||||||
+AM_CPPFLAGS += $(SYSTEMD_CFLAGS) $(SYSTEMD_JOURNAL_CFLAGS) -DSYSTEMD
|
|
||||||
|
|
||||||
-rpcbind_LDADD += $(SYSTEMD_LIBS)
|
|
||||||
+rpcbind_LDADD += $(SYSTEMD_LIBS) $(SYSTEMD_JOURNAL_LIBS)
|
|
||||||
|
|
||||||
systemd/rpcbind.service: systemd/rpcbind.service.in Makefile
|
|
||||||
sed -e 's,@bindir\@,$(bindir),g' \
|
|
@ -1,23 +0,0 @@
|
|||||||
--- rpcbind-0.2.0_git201103171419.orig/src/rpcbind.c
|
|
||||||
+++ rpcbind-0.2.0_git201103171419/src/rpcbind.c
|
|
||||||
@@ -253,7 +253,9 @@ main(int argc, char *argv[])
|
|
||||||
#endif
|
|
||||||
|
|
||||||
network_init();
|
|
||||||
-
|
|
||||||
+#ifdef SYSTEMD
|
|
||||||
+ sd_notify(0, "READY=1");
|
|
||||||
+#endif
|
|
||||||
my_svc_run();
|
|
||||||
rpcbind_syslog(LOG_ERR, "svc_run returned unexpectedly");
|
|
||||||
rpcbind_abort();
|
|
||||||
--- rpcbind-0.2.0_git201103171419.orig/systemd/rpcbind.service.in
|
|
||||||
+++ rpcbind-0.2.0_git201103171419/systemd/rpcbind.service.in
|
|
||||||
@@ -2,6 +2,7 @@
|
|
||||||
Description=RPC Bind
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
+Type=notify
|
|
||||||
ExecStart=@bindir@/rpcbind -w -f
|
|
||||||
|
|
||||||
[Install]
|
|
@ -1,3 +1,49 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Jan 14 16:18:49 UTC 2014 - okir@suse.com
|
||||||
|
|
||||||
|
- Recognize RPCBIND_OPTIONS from /etc/sysconfig/rpcbind (bnc#824621)
|
||||||
|
Added:
|
||||||
|
0015-Pull-the-sysconfig-file-into-rpcbind.service-and-use.patch
|
||||||
|
- Make rpcbind run as user "rpc" by default (bnc#714735)
|
||||||
|
- Avoid NIS lookups of host names and service names (bnc#858700)
|
||||||
|
Added:
|
||||||
|
0016-configure-check-for-nss.h.patch
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Fri Jan 10 10:58:47 UTC 2014 - okir@suse.com
|
||||||
|
|
||||||
|
- Notify systemd unconditionally. This prevented
|
||||||
|
"systemctl start rpcbind.service" from succeeding
|
||||||
|
Added:
|
||||||
|
0014-Notify-systemd-unconditionally.patch
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Aug 20 18:34:19 UTC 2013 - okir@suse.com
|
||||||
|
|
||||||
|
- Update rpcbind to latest upstream, and rewrote patches for systemd
|
||||||
|
integration.
|
||||||
|
Removed:
|
||||||
|
0001-systemd-add-support-for-system-bus-activation.patch
|
||||||
|
socket-activation-don-t-unlink-socket-we-didn-t-create
|
||||||
|
socket-activation-fix-rpcbind-service-to-use-separate-sockets
|
||||||
|
rpcbind-journal.patch
|
||||||
|
move-lock-file-to-run-fs.patch
|
||||||
|
rpcbind-systemd-notify.patch
|
||||||
|
Added:
|
||||||
|
0001-Silence-a-warning-about-setgroups-being-implicitly-d.patch
|
||||||
|
0002-Remove-obsolete-function-in6_fillscopeid.patch
|
||||||
|
0003-configure-fix-the-case-when-with-rpcuser-is-not-give.patch
|
||||||
|
0004-In-init_transport-move-creation-of-COTS-sockets-clos.patch
|
||||||
|
0005-The-use-of-AI_NUMERICHOST-in-init_transport-is-broke.patch
|
||||||
|
0006-First-part-of-init_transport-refactoring.patch
|
||||||
|
0007-init_transport-move-the-registration-code-into-a-sep.patch
|
||||||
|
0008-Fix-the-behavior-when-specifying-the-h-option.patch
|
||||||
|
0009-Clean-up-the-way-we-handle-the-h-option-in-init_tran.patch
|
||||||
|
0010-Support-systemd-activation.patch
|
||||||
|
0011-socket-activation-Fix-rpcbind.service-to-use-separat.patch
|
||||||
|
0012-When-using-systemd-redirect-syslog-calls-to-the-syst.patch
|
||||||
|
0013-When-using-systemd-activation-make-rpcbind-notify-sy.patch
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Thu Jun 27 21:36:52 UTC 2013 - crrodriguez@opensuse.org
|
Thu Jun 27 21:36:52 UTC 2013 - crrodriguez@opensuse.org
|
||||||
|
|
||||||
|
46
rpcbind.spec
46
rpcbind.spec
@ -1,7 +1,7 @@
|
|||||||
#
|
#
|
||||||
# spec file for package rpcbind
|
# spec file for package rpcbind
|
||||||
#
|
#
|
||||||
# Copyright (c) 2013 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
# Copyright (c) 2014 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
||||||
#
|
#
|
||||||
# All modifications and additions to the file contributed by third parties
|
# All modifications and additions to the file contributed by third parties
|
||||||
# remain the property of their copyright owners, unless otherwise agreed
|
# remain the property of their copyright owners, unless otherwise agreed
|
||||||
@ -17,7 +17,7 @@
|
|||||||
|
|
||||||
|
|
||||||
Name: rpcbind
|
Name: rpcbind
|
||||||
Version: 0.2.0_git201103171419
|
Version: 0.2.1_git1b0fdf5
|
||||||
Release: 0
|
Release: 0
|
||||||
Summary: Transport independent RPC portmapper
|
Summary: Transport independent RPC portmapper
|
||||||
License: BSD-4-Clause
|
License: BSD-4-Clause
|
||||||
@ -33,12 +33,22 @@ BuildRequires: libtool
|
|||||||
BuildRequires: pkgconfig
|
BuildRequires: pkgconfig
|
||||||
BuildRequires: tcpd-devel
|
BuildRequires: tcpd-devel
|
||||||
PreReq: %fillup_prereq
|
PreReq: %fillup_prereq
|
||||||
Patch0: 0001-systemd-add-support-for-system-bus-activation.patch
|
Patch0: 0001-Silence-a-warning-about-setgroups-being-implicitly-d.patch
|
||||||
Patch1: socket-activation-don-t-unlink-socket-we-didn-t-create
|
Patch1: 0002-Remove-obsolete-function-in6_fillscopeid.patch
|
||||||
Patch2: socket-activation-fix-rpcbind-service-to-use-separate-sockets
|
Patch2: 0003-configure-fix-the-case-when-with-rpcuser-is-not-give.patch
|
||||||
Patch3: rpcbind-journal.patch
|
Patch3: 0004-In-init_transport-move-creation-of-COTS-sockets-clos.patch
|
||||||
Patch4: move-lock-file-to-run-fs.patch
|
Patch4: 0005-The-use-of-AI_NUMERICHOST-in-init_transport-is-broke.patch
|
||||||
Patch5: rpcbind-systemd-notify.patch
|
Patch5: 0006-First-part-of-init_transport-refactoring.patch
|
||||||
|
Patch6: 0007-init_transport-move-the-registration-code-into-a-sep.patch
|
||||||
|
Patch7: 0008-Fix-the-behavior-when-specifying-the-h-option.patch
|
||||||
|
Patch8: 0009-Clean-up-the-way-we-handle-the-h-option-in-init_tran.patch
|
||||||
|
Patch9: 0010-Support-systemd-activation.patch
|
||||||
|
Patch10: 0011-socket-activation-Fix-rpcbind.service-to-use-separat.patch
|
||||||
|
Patch11: 0012-When-using-systemd-redirect-syslog-calls-to-the-syst.patch
|
||||||
|
Patch12: 0013-When-using-systemd-activation-make-rpcbind-notify-sy.patch
|
||||||
|
Patch13: 0014-Notify-systemd-unconditionally.patch
|
||||||
|
Patch14: 0015-Pull-the-sysconfig-file-into-rpcbind.service-and-use.patch
|
||||||
|
Patch15: 0016-configure-check-for-nss.h.patch
|
||||||
%define statefile /var/lib/portmap.state
|
%define statefile /var/lib/portmap.state
|
||||||
BuildRequires: pkgconfig(systemd)
|
BuildRequires: pkgconfig(systemd)
|
||||||
%{?systemd_requires}
|
%{?systemd_requires}
|
||||||
@ -64,9 +74,19 @@ cp %{SOURCE4} .
|
|||||||
%patch0 -p1
|
%patch0 -p1
|
||||||
%patch1 -p1
|
%patch1 -p1
|
||||||
%patch2 -p1
|
%patch2 -p1
|
||||||
%patch3
|
%patch3 -p1
|
||||||
%patch4 -p1
|
%patch4 -p1
|
||||||
%patch5 -p1
|
%patch5 -p1
|
||||||
|
%patch6 -p1
|
||||||
|
%patch7 -p1
|
||||||
|
%patch8 -p1
|
||||||
|
%patch9 -p1
|
||||||
|
%patch10 -p1
|
||||||
|
%patch11 -p1
|
||||||
|
%patch12 -p1
|
||||||
|
%patch13 -p1
|
||||||
|
%patch14 -p1
|
||||||
|
%patch15 -p1
|
||||||
|
|
||||||
%build
|
%build
|
||||||
autoreconf -fiv
|
autoreconf -fiv
|
||||||
@ -76,7 +96,9 @@ export LDFLAGS="-pie -Wl,-z,relro,-z,now"
|
|||||||
--bindir=/sbin \
|
--bindir=/sbin \
|
||||||
--enable-libwrap \
|
--enable-libwrap \
|
||||||
--enable-warmstarts \
|
--enable-warmstarts \
|
||||||
--with-statedir=%{_localstatedir}/lib/rpcbind
|
--enable-debug \
|
||||||
|
--with-statedir=%{_localstatedir}/lib/rpcbind \
|
||||||
|
--with-rpcuser=rpc
|
||||||
|
|
||||||
%{__make} %{?jobs:-j%jobs}
|
%{__make} %{?jobs:-j%jobs}
|
||||||
%{__cc} -pie -fpie -fwhole-program -Wl,-z,relro,-z,now %{optflags} pmap_set.c -o pmap_set
|
%{__cc} -pie -fpie -fwhole-program -Wl,-z,relro,-z,now %{optflags} pmap_set.c -o pmap_set
|
||||||
@ -98,6 +120,10 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
%pre
|
%pre
|
||||||
%service_add_pre %{name}.service %{name}.socket
|
%service_add_pre %{name}.service %{name}.socket
|
||||||
|
|
||||||
|
# Add "rpc" user
|
||||||
|
getent passwd rpc >/dev/null || useradd -r -g nogroup -d /var/lib/emptry -s /sbin/nologin -c "user for rpcbind" rpc
|
||||||
|
exit 0
|
||||||
|
|
||||||
%preun
|
%preun
|
||||||
%service_del_preun %{name}.service %{name}.socket
|
%service_del_preun %{name}.service %{name}.socket
|
||||||
|
|
||||||
|
@ -1,61 +0,0 @@
|
|||||||
From: Jeff Mahoney <jeffm@suse.com>
|
|
||||||
Subject: socket-activation: don't unlink socket we didn't create
|
|
||||||
References: bnc#757667
|
|
||||||
|
|
||||||
On an unpatched system, try this:
|
|
||||||
rpcinfo <works>
|
|
||||||
rcrpcbind restart
|
|
||||||
rpcinfo <fails>
|
|
||||||
|
|
||||||
This is due to rpcbind unlinking the socket file when it exits. It
|
|
||||||
doesn't own the socket file when socket activation is used - systemd
|
|
||||||
does. Systemd still has an open reference to it and when rpcbind is
|
|
||||||
restarted, it passes the open reference back to it and rpcbind is
|
|
||||||
perfectly happy to accept it. Unfortunately, everything that needs to
|
|
||||||
talk to rpcbind no longer can because the socket file each of those
|
|
||||||
users needs to open is no longer on the file system.
|
|
||||||
|
|
||||||
This patch adds a new global that's used to avoid unlinking the
|
|
||||||
rpcbind.sock socket file during shutdown.
|
|
||||||
|
|
||||||
Signed-off-by: Jeff Mahoney <jeffm@suse.com>
|
|
||||||
---
|
|
||||||
|
|
||||||
src/rpcbind.c | 12 +++++++++++-
|
|
||||||
1 file changed, 11 insertions(+), 1 deletion(-)
|
|
||||||
|
|
||||||
--- a/src/rpcbind.c
|
|
||||||
+++ b/src/rpcbind.c
|
|
||||||
@@ -80,6 +81,7 @@
|
|
||||||
int debugging = 0; /* Tell me what's going on */
|
|
||||||
int doabort = 0; /* When debugging, do an abort on errors */
|
|
||||||
int dofork = 1; /* fork? */
|
|
||||||
+int sock_needs_unlink = 1; /* we created rpcbind.sock */
|
|
||||||
|
|
||||||
rpcblist_ptr list_rbl; /* A list of version 3/4 rpcbind services */
|
|
||||||
|
|
||||||
@@ -365,6 +396,14 @@ init_transport(struct netconfig *nconf)
|
|
||||||
nconf->nc_netid);
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * We were passed the open UNIX socket
|
|
||||||
+ * and shouldn't remove it.
|
|
||||||
+ */
|
|
||||||
+ if (sa.sa.sa_family == AF_UNIX &&
|
|
||||||
+ strcmp(sa.un.sun_path, _PATH_RPCBINDSOCK))
|
|
||||||
+ sock_needs_unlink = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* if none of the systemd sockets matched, we set up the socket in
|
|
||||||
@@ -784,7 +823,8 @@ static void
|
|
||||||
terminate(int dummy /*__unused*/)
|
|
||||||
{
|
|
||||||
close(rpcbindlockfd);
|
|
||||||
- unlink(_PATH_RPCBINDSOCK);
|
|
||||||
+ if (sock_needs_unlink)
|
|
||||||
+ unlink(_PATH_RPCBINDSOCK);
|
|
||||||
unlink(RPCBINDDLOCK);
|
|
||||||
#ifdef WARMSTART
|
|
||||||
syslog(LOG_ERR,
|
|
Loading…
Reference in New Issue
Block a user