summaryrefslogtreecommitdiffstats
path: root/lib/libc/gen/getpwent.c
diff options
context:
space:
mode:
authorwpaul <wpaul@FreeBSD.org>1995-04-14 14:56:28 +0000
committerwpaul <wpaul@FreeBSD.org>1995-04-14 14:56:28 +0000
commit3ce68508565a04b191a7642e35ddbfeaef1c0c67 (patch)
tree9b493b33bde5b4a444daac86b00436dee818d5b6 /lib/libc/gen/getpwent.c
parentd9a6e86fa730cc34ffa056db652632c99559cf0a (diff)
downloadFreeBSD-src-3ce68508565a04b191a7642e35ddbfeaef1c0c67.zip
FreeBSD-src-3ce68508565a04b191a7642e35ddbfeaef1c0c67.tar.gz
Better conformance to SunOS behavior: if we can't match a user to one
of the plus or minus lists at all, reject him. This lets you create a +@netgroup list of users that you want to admit and reject everybody else. If you end your +@netgroup list with the wildcard line (+:::::::::) then you'll have a +@netgroup list that remaps the specified people but leaves people not in any netgroup unaffected.
Diffstat (limited to 'lib/libc/gen/getpwent.c')
-rw-r--r--lib/libc/gen/getpwent.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/lib/libc/gen/getpwent.c b/lib/libc/gen/getpwent.c
index 7c693e3..b8f1b19 100644
--- a/lib/libc/gen/getpwent.c
+++ b/lib/libc/gen/getpwent.c
@@ -604,7 +604,7 @@ _getyppass(struct passwd *pw, const char *name, const char *map)
if(resultlen >= sizeof resultbuf) return 0;
strcpy(resultbuf, result);
sprintf (user, "%.*s", (strchr(result, ':') - result), result);
- _pw_passwd.pw_fields = 0;
+ _pw_passwd.pw_fields = -1; /* Impossible value */
if (_minuscnt && _minushead) {
m = _minushead;
while (m) {
@@ -633,6 +633,9 @@ _getyppass(struct passwd *pw, const char *name, const char *map)
}
}
free(result);
+ /* No hits in the plus or minus lists: Bzzt! reject. */
+ if (_pw_passwd.pw_fields == -1)
+ return(0);
result = resultbuf;
_pw_breakout_yp(pw, resultbuf, gotmaster);
@@ -694,7 +697,7 @@ unpack:
strcpy(resultbuf, result);
sprintf(user, "%.*s", (strchr(result, ':') - result), result);
- _pw_passwd.pw_fields = 0;
+ _pw_passwd.pw_fields = -1; /* Impossible value */
if (_minuscnt && _minushead) {
m = _minushead;
while (m) {
@@ -723,6 +726,9 @@ unpack:
}
}
free(result);
+ /* No plus or minus hits: Bzzzt! reject. */
+ if (_pw_passwd.pw_fields == -1)
+ goto tryagain;
if(result = strchr(resultbuf, '\n')) *result = '\0';
_pw_breakout_yp(pw, resultbuf, gotmaster);
}
OpenPOWER on IntegriCloud