summaryrefslogtreecommitdiffstats
path: root/libexec/rpc.rusersd
diff options
context:
space:
mode:
authoralfred <alfred@FreeBSD.org>2002-07-15 18:51:57 +0000
committeralfred <alfred@FreeBSD.org>2002-07-15 18:51:57 +0000
commit83a53d0868085db818fddd8cb38eecc0c39cad8d (patch)
treea7c706e5ad9f636ce740a033b0fa75319465add7 /libexec/rpc.rusersd
parent08255d70df400237c666515b55e2726296ded480 (diff)
downloadFreeBSD-src-83a53d0868085db818fddd8cb38eecc0c39cad8d.zip
FreeBSD-src-83a53d0868085db818fddd8cb38eecc0c39cad8d.tar.gz
Port to TI/RPC and/or IPV6.
Submitted by: Jean-Luc Richier <Jean-Luc.Richier@imag.fr>
Diffstat (limited to 'libexec/rpc.rusersd')
-rw-r--r--libexec/rpc.rusersd/rusersd.c48
1 files changed, 28 insertions, 20 deletions
diff --git a/libexec/rpc.rusersd/rusersd.c b/libexec/rpc.rusersd/rusersd.c
index fc4640f..9ffc4b3 100644
--- a/libexec/rpc.rusersd/rusersd.c
+++ b/libexec/rpc.rusersd/rusersd.c
@@ -38,7 +38,7 @@ static const char rcsid[] =
#include <stdlib.h>
#include <rpc/rpc.h>
-#include <rpc/pmap_clnt.h>
+#include <sys/socket.h>
#include <signal.h>
#include <syslog.h>
#define utmp rutmp
@@ -52,8 +52,8 @@ int from_inetd = 1;
void
cleanup(int sig __unused)
{
- (void) pmap_unset(RUSERSPROG, RUSERSVERS_IDLE);
- (void) pmap_unset(RUSERSPROG, RUSERSVERS_ORIG);
+ (void) rpcb_unset(RUSERSPROG, RUSERSVERS_IDLE, NULL);
+ (void) rpcb_unset(RUSERSPROG, RUSERSVERS_ORIG, NULL);
exit(0);
}
@@ -61,9 +61,8 @@ int
main(int argc, char *argv[])
{
SVCXPRT *transp;
- int sock = 0;
- int proto = 0;
- struct sockaddr_in from;
+ int ok;
+ struct sockaddr_storage from;
int fromlen;
/*
@@ -72,15 +71,13 @@ main(int argc, char *argv[])
fromlen = sizeof(from);
if (getsockname(0, (struct sockaddr *)&from, &fromlen) < 0) {
from_inetd = 0;
- sock = RPC_ANYSOCK;
- proto = IPPROTO_UDP;
}
if (!from_inetd) {
daemon(0, 0);
- (void) pmap_unset(RUSERSPROG, RUSERSVERS_IDLE);
- (void) pmap_unset(RUSERSPROG, RUSERSVERS_ORIG);
+ (void) rpcb_unset(RUSERSPROG, RUSERSVERS_IDLE, NULL);
+ (void) rpcb_unset(RUSERSPROG, RUSERSVERS_ORIG, NULL);
(void) signal(SIGINT, cleanup);
(void) signal(SIGTERM, cleanup);
@@ -89,18 +86,29 @@ main(int argc, char *argv[])
openlog("rpc.rusersd", LOG_CONS|LOG_PID, LOG_DAEMON);
- transp = svcudp_create(sock);
- if (transp == NULL) {
- syslog(LOG_ERR, "cannot create udp service");
+ if (from_inetd) {
+ transp = svc_tli_create(0, NULL, NULL, 0, 0);
+ if (transp == NULL) {
+ syslog(LOG_ERR, "cannot create udp service.");
+ exit(1);
+ }
+ ok = svc_reg(transp, RUSERSPROG, RUSERSVERS_IDLE,
+ rusers_service, NULL);
+ } else
+ ok = svc_create(rusers_service,
+ RUSERSPROG, RUSERSVERS_IDLE, "udp");
+ if (!ok) {
+ syslog(LOG_ERR, "unable to register (RUSERSPROG, RUSERSVERS_IDLE, %s)", (!from_inetd)?"udp":"(inetd)");
exit(1);
}
- if (!svc_register(transp, RUSERSPROG, RUSERSVERS_IDLE, rusers_service, proto)) {
- syslog(LOG_ERR, "unable to register (RUSERSPROG, RUSERSVERS_IDLE, %s)", proto?"udp":"(inetd)");
- exit(1);
- }
-
- if (!svc_register(transp, RUSERSPROG, RUSERSVERS_ORIG, rusers_service, proto)) {
- syslog(LOG_ERR, "unable to register (RUSERSPROG, RUSERSVERS_ORIG, %s)", proto?"udp":"(inetd)");
+ if (from_inetd)
+ ok = svc_reg(transp, RUSERSPROG, RUSERSVERS_ORIG,
+ rusers_service, NULL);
+ else
+ ok = svc_create(rusers_service,
+ RUSERSPROG, RUSERSVERS_ORIG, "udp");
+ if (!ok) {
+ syslog(LOG_ERR, "unable to register (RUSERSPROG, RUSERSVERS_ORIG, %s)", (!from_inetd)?"udp":"(inetd)");
exit(1);
}
OpenPOWER on IntegriCloud