From 32e5dd1f22a1799c634dbb8b41feb7601e38266b Mon Sep 17 00:00:00 2001 From: lukem Date: Mon, 8 Jun 1998 03:12:45 +0000 Subject: [PATCH] move pw_scan() out of here (into libc) document _PASSWORD_NOWARN and _PASSWORD_OLDFMT inflags to pw_scan() --- lib/libutil/passwd.c | 102 +++++------------------------------------- lib/libutil/pw_init.3 | 18 ++++++-- 2 files changed, 25 insertions(+), 95 deletions(-) diff --git a/lib/libutil/passwd.c b/lib/libutil/passwd.c index b218f07623ed..7ec5adb4c72c 100644 --- a/lib/libutil/passwd.c +++ b/lib/libutil/passwd.c @@ -1,4 +1,4 @@ -/* $NetBSD: passwd.c,v 1.11 1997/12/31 05:47:15 thorpej Exp $ */ +/* $NetBSD: passwd.c,v 1.12 1998/06/08 03:12:45 lukem Exp $ */ /* * Copyright (c) 1987, 1993, 1994, 1995 @@ -35,7 +35,7 @@ #include #if defined(LIBC_SCCS) && !defined(lint) -__RCSID("$NetBSD: passwd.c,v 1.11 1997/12/31 05:47:15 thorpej Exp $"); +__RCSID("$NetBSD: passwd.c,v 1.12 1998/06/08 03:12:45 lukem Exp $"); #endif /* LIBC_SCCS and not lint */ #include @@ -46,16 +46,16 @@ __RCSID("$NetBSD: passwd.c,v 1.11 1997/12/31 05:47:15 thorpej Exp $"); #include #include -#include -#include -#include -#include -#include -#include #include -#include -#include +#include #include +#include +#include +#include +#include +#include +#include +#include #include static void pw_cont __P((int sig)); @@ -329,87 +329,6 @@ err: pw_error(NULL, 1, 1); (void)fclose(to); } -int -pw_scan(bp, pw, flags) - char *bp; - struct passwd *pw; - int *flags; -{ - unsigned long id; - int root; - char *p, *sh, *ep; - - if (flags != (int *)NULL) - *flags = 0; - - if (!(pw->pw_name = strsep(&bp, ":"))) /* login */ - goto fmt; - root = !strcmp(pw->pw_name, "root"); - - if (!(pw->pw_passwd = strsep(&bp, ":"))) /* passwd */ - goto fmt; - - if (!(p = strsep(&bp, ":"))) /* uid */ - goto fmt; - id = strtoul(p, &ep, 10); - if (root && id) { - warnx("root uid should be 0"); - return (0); - } - if (id > UID_MAX || *ep != '\0') { - warnx("invalid uid '%s'", p); - return (0); - } - pw->pw_uid = (uid_t)id; - if ((*p == '\0') && (flags != (int *)NULL)) - *flags |= _PASSWORD_NOUID; - - if (!(p = strsep(&bp, ":"))) /* gid */ - goto fmt; - id = strtoul(p, &ep, 10); - if (id > GID_MAX || *ep != '\0') { - warnx("invalid gid '%s'", p); - return (0); - } - pw->pw_gid = (gid_t)id; - if ((*p == '\0') && (flags != (int *)NULL)) - *flags |= _PASSWORD_NOGID; - - pw->pw_class = strsep(&bp, ":"); /* class */ - if (!(p = strsep(&bp, ":"))) /* change */ - goto fmt; - pw->pw_change = atol(p); - if ((*p == '\0') && (flags != (int *)NULL)) - *flags |= _PASSWORD_NOCHG; - if (!(p = strsep(&bp, ":"))) /* expire */ - goto fmt; - pw->pw_expire = atol(p); - if ((*p == '\0') && (flags != (int *)NULL)) - *flags |= _PASSWORD_NOEXP; - pw->pw_gecos = strsep(&bp, ":"); /* gecos */ - pw->pw_dir = strsep(&bp, ":"); /* directory */ - if (!(pw->pw_shell = strsep(&bp, ":"))) /* shell */ - goto fmt; - - p = pw->pw_shell; - if (root && *p) /* empty == /bin/sh */ - for (setusershell();;) { - if (!(sh = getusershell())) { - warnx("warning, unknown root shell"); - break; - } - if (!strcmp(p, sh)) - break; - } - - if ((p = strsep(&bp, ":"))) { /* too many */ -fmt: warnx("corrupted entry"); - return (0); - } - - return (1); -} - void pw_error(name, err, eval) const char *name; @@ -422,4 +341,3 @@ pw_error(name, err, eval) pw_abort(); exit(eval); } - diff --git a/lib/libutil/pw_init.3 b/lib/libutil/pw_init.3 index ccbeb5f4e22d..6c5af866607f 100644 --- a/lib/libutil/pw_init.3 +++ b/lib/libutil/pw_init.3 @@ -1,4 +1,4 @@ -.\" $NetBSD: pw_init.3,v 1.4 1998/02/05 18:52:29 perry Exp $ +.\" $NetBSD: pw_init.3,v 1.5 1998/06/08 03:12:45 lukem Exp $ .\" .\" Copyright (c) 1995 .\" The Regents of the University of California. All rights reserved. @@ -138,8 +138,20 @@ to by .Fa pw . If .Fa flags -is non-null, it is filled in with the following flags: -.Bl -tag -width _PASSWORD_NOGIDxxx +is non-null, it should be cleared and the following options +enabled if required: +.Bl -tag -offset indent -width _PASSWORD_OLDFMT +.It Dv _PASSWORD_NOWARN +Don't print warnings. +.It Dv _PASSWORD_OLDFMT +Parse +.Fa bp +as an old format entry as found in +.Pa /etc/passwd . +.El +.Pp +Upon return it is cleared, and filled in with the following flags: +.Bl -tag -offset indent -width _PASSWORD_NOGID .It Dv _PASSWORD_NOUID The uid field of .Fa bp