3 * David L. Nugent. All rights reserved.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
14 * THIS SOFTWARE IS PROVIDED BY DAVID L. NUGENT AND CONTRIBUTORS ``AS IS'' AND
15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17 * ARE DISCLAIMED. IN NO EVENT SHALL DAVID L. NUGENT OR CONTRIBUTORS BE LIABLE
18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 static const char rcsid[] =
36 #include <sys/param.h>
40 static FILE * pwd_fp = NULL;
57 static struct passwd *
58 vnextpwent(char const * nam, uid_t uid, int doclose)
60 struct passwd * pw = NULL;
61 static char pwtmp[1024];
63 strlcpy(pwtmp, getpwpath(_MASTERPASSWD), sizeof(pwtmp));
65 if (pwd_fp != NULL || (pwd_fp = fopen(pwtmp, "r")) != NULL) {
68 static struct passwd pwd;
70 while (!done && fgets(pwtmp, sizeof pwtmp, pwd_fp) != NULL)
74 char * p = strchr(pwtmp, '\n');
77 while (fgets(pwtmp, sizeof pwtmp, pwd_fp) != NULL && strchr(pwtmp, '\n')==NULL)
78 ; /* Skip long lines */
82 /* skip comments & empty lines */
83 if (*pwtmp =='\n' || *pwtmp == '#')
88 bzero(&pwd, sizeof pwd);
89 while (!quickout && (p = strsep(&q, ":\n")) != NULL) {
92 case 0: /* username */
95 if (strcmp(nam, p) == 0)
101 case 1: /* password */
105 pwd.pw_uid = atoi(p);
106 if (uid != (uid_t)-1) {
107 if (uid == pwd.pw_uid)
114 pwd.pw_gid = atoi(p);
117 if (nam == NULL && uid == (uid_t)-1)
122 pwd.pw_change = (time_t)atol(p);
125 pwd.pw_expire = (time_t)atol(p);
130 case 8: /* directory */
141 if (done && pwd.pw_name) {
144 #define CKNULL(s) s = s ? s : ""
145 CKNULL(pwd.pw_passwd);
146 CKNULL(pwd.pw_class);
147 CKNULL(pwd.pw_gecos);
149 CKNULL(pwd.pw_shell);
158 return vnextpwent(NULL, -1, 0);
164 return vnextpwent(NULL, uid, 1);
168 vgetpwnam(const char * nam)
170 return vnextpwent(nam, -1, 1);
173 int vpwdb(char *arg, ...)
181 static FILE * grp_fp = NULL;
186 if (grp_fp != NULL) {
196 #if defined(__FreeBSD__)
201 static struct group *
202 vnextgrent(char const * nam, gid_t gid, int doclose)
204 struct group * gr = NULL;
206 static char * grtmp = NULL;
207 static int grlen = 0;
208 static char ** mems = NULL;
209 static int memlen = 0;
211 extendline(&grtmp, &grlen, MAXPATHLEN);
212 strlcpy(grtmp, getgrpath(_GROUP), MAXPATHLEN);
214 if (grp_fp != NULL || (grp_fp = fopen(grtmp, "r")) != NULL) {
217 static struct group grp;
219 while (!done && fgets(grtmp, grlen, grp_fp) != NULL)
226 if ((p = strchr(grtmp, '\n')) == NULL) {
228 extendline(&grtmp, &grlen, grlen + PWBUFSZ);
230 if (fgets(grtmp + l, grlen - l, grp_fp) == NULL)
231 break; /* No newline terminator on last line */
233 /* Skip comments and empty lines */
234 if (*grtmp == '\n' || *grtmp == '#')
238 bzero(&grp, sizeof grp);
239 extendarray(&mems, &memlen, 200);
240 while (!quickout && (p = strsep(&q, sep)) != NULL) {
243 case 0: /* groupname */
246 if (strcmp(nam, p) == 0)
252 case 1: /* password */
256 grp.gr_gid = atoi(p);
257 if (gid != (gid_t)-1) {
258 if (gid == (gid_t)grp.gr_gid)
262 } else if (nam == NULL)
271 extendarray(&mems, &memlen, mno + 2);
282 if (done && grp.gr_name) {
285 CKNULL(grp.gr_passwd);
294 return vnextgrent(NULL, -1, 0);
301 return vnextgrent(NULL, gid, 1);
305 vgetgrnam(const char * nam)
307 return vnextgrent(nam, -1, 1);
311 vgrdb(char *arg, ...)