diff options
| author | millert <> | 1996-08-30 04:07:43 +0000 |
|---|---|---|
| committer | millert <> | 1996-08-30 04:07:43 +0000 |
| commit | 7c879143c6af188f0f2bce32888bc5381e355397 (patch) | |
| tree | 0bb93db87324ed88232401b5d2a88c204d597547 /src/lib/libc/net/rcmd.c | |
| parent | 8d02734af47aa7ce280520bc702bc108ce70e83a (diff) | |
| download | openbsd-7c879143c6af188f0f2bce32888bc5381e355397.tar.gz openbsd-7c879143c6af188f0f2bce32888bc5381e355397.tar.bz2 openbsd-7c879143c6af188f0f2bce32888bc5381e355397.zip | |
call rcmdsh() if euid != 0 and port is shell/tcp. This lets us
get away with fewer setuid binaries.
Diffstat (limited to 'src/lib/libc/net/rcmd.c')
| -rw-r--r-- | src/lib/libc/net/rcmd.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/src/lib/libc/net/rcmd.c b/src/lib/libc/net/rcmd.c index ef98e882a2..2530c9d5a2 100644 --- a/src/lib/libc/net/rcmd.c +++ b/src/lib/libc/net/rcmd.c | |||
| @@ -32,7 +32,7 @@ | |||
| 32 | */ | 32 | */ |
| 33 | 33 | ||
| 34 | #if defined(LIBC_SCCS) && !defined(lint) | 34 | #if defined(LIBC_SCCS) && !defined(lint) |
| 35 | static char *rcsid = "$OpenBSD: rcmd.c,v 1.11 1996/08/19 08:29:39 tholo Exp $"; | 35 | static char *rcsid = "$OpenBSD: rcmd.c,v 1.12 1996/08/30 04:07:43 millert Exp $"; |
| 36 | #endif /* LIBC_SCCS and not lint */ | 36 | #endif /* LIBC_SCCS and not lint */ |
| 37 | 37 | ||
| 38 | #include <sys/param.h> | 38 | #include <sys/param.h> |
| @@ -72,6 +72,13 @@ rcmd(ahost, rport, locuser, remuser, cmd, fd2p) | |||
| 72 | int s, lport, timo; | 72 | int s, lport, timo; |
| 73 | char c; | 73 | char c; |
| 74 | 74 | ||
| 75 | /* use rsh(1) if non-root and remote port is shell. */ | ||
| 76 | if (geteuid()) { | ||
| 77 | struct servent *sp = getservbyname("shell", "tcp"); | ||
| 78 | if (sp && sp->s_port == rport) | ||
| 79 | return(rcmdsh(ahost, rport, locuser, remuser, cmd, NULL)); | ||
| 80 | } | ||
| 81 | |||
| 75 | pid = getpid(); | 82 | pid = getpid(); |
| 76 | hp = gethostbyname(*ahost); | 83 | hp = gethostbyname(*ahost); |
| 77 | if (hp == NULL) { | 84 | if (hp == NULL) { |
| @@ -79,6 +86,7 @@ rcmd(ahost, rport, locuser, remuser, cmd, fd2p) | |||
| 79 | return (-1); | 86 | return (-1); |
| 80 | } | 87 | } |
| 81 | *ahost = hp->h_name; | 88 | *ahost = hp->h_name; |
| 89 | |||
| 82 | oldmask = sigblock(sigmask(SIGURG)); | 90 | oldmask = sigblock(sigmask(SIGURG)); |
| 83 | for (timo = 1, lport = IPPORT_RESERVED - 1;;) { | 91 | for (timo = 1, lport = IPPORT_RESERVED - 1;;) { |
| 84 | s = rresvport(&lport); | 92 | s = rresvport(&lport); |
