From 7ca3831b82d66e7ee9716d36fc0278897e6d0858 Mon Sep 17 00:00:00 2001 From: deraadt <> Date: Sun, 6 Jul 1997 07:55:58 +0000 Subject: if we find an unprintable char, bail totally --- src/lib/libc/net/rcmd.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/lib/libc/net/rcmd.c b/src/lib/libc/net/rcmd.c index ae746f5301..6e3ee93caf 100644 --- a/src/lib/libc/net/rcmd.c +++ b/src/lib/libc/net/rcmd.c @@ -34,7 +34,7 @@ */ #if defined(LIBC_SCCS) && !defined(lint) -static char *rcsid = "$OpenBSD: rcmd.c,v 1.24 1997/06/29 06:02:48 deraadt Exp $"; +static char *rcsid = "$OpenBSD: rcmd.c,v 1.25 1997/07/06 07:55:58 deraadt Exp $"; #endif /* LIBC_SCCS and not lint */ #include @@ -422,6 +422,8 @@ __ivaliduser(hostf, raddrl, luser, ruser) if (*p == '#') continue; while (*p != '\n' && *p != ' ' && *p != '\t' && *p != '\0') { + if (!isprint(*p)) + goto bail; *p = isupper(*p) ? tolower(*p) : *p; p++; } @@ -527,6 +529,7 @@ __ivaliduser(hostf, raddrl, luser, ruser) if (hostok >= 1 && userok >= 1) return (0); } +bail: return (-1); } -- cgit v1.2.3-55-g6feb