]>
git.saurik.com Git - apple/system_cmds.git/blob - vipw.tproj/pw_util.c
2 * Copyright (c) 1999 Apple Computer, Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * "Portions Copyright (c) 1999 Apple Computer, Inc. All Rights
7 * Reserved. This file contains Original Code and/or Modifications of
8 * Original Code as defined in and that are subject to the Apple Public
9 * Source License Version 1.0 (the 'License'). You may not use this file
10 * except in compliance with the License. Please obtain a copy of the
11 * License at http://www.apple.com/publicsource and read it before using
14 * The Original Code and all software distributed under the License are
15 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
16 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
17 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
19 * License for the specific language governing rights and limitations
22 * @APPLE_LICENSE_HEADER_END@
25 * Copyright (c) 1990, 1993, 1994
26 * The Regents of the University of California. All rights reserved.
28 * Redistribution and use in source and binary forms, with or without
29 * modification, are permitted provided that the following conditions
31 * 1. Redistributions of source code must retain the above copyright
32 * notice, this list of conditions and the following disclaimer.
33 * 2. Redistributions in binary form must reproduce the above copyright
34 * notice, this list of conditions and the following disclaimer in the
35 * documentation and/or other materials provided with the distribution.
36 * 3. All advertising materials mentioning features or use of this software
37 * must display the following acknowledgement:
38 * This product includes software developed by the University of
39 * California, Berkeley and its contributors.
40 * 4. Neither the name of the University nor the names of its contributors
41 * may be used to endorse or promote products derived from this software
42 * without specific prior written permission.
44 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
45 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
46 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
47 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
48 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
49 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
50 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
51 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
52 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
53 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
58 static char sccsid
[] = "@(#)pw_util.c 8.4 (Berkeley) 4/28/95";
62 * This file is used by all the "password" programs; vipw(8), chpass(1),
66 #include <sys/param.h>
68 #include <sys/resource.h>
85 extern char *tempname
;
86 static pid_t editpid
= -1;
103 /* Unlimited resource limits. */
104 rlim
.rlim_cur
= rlim
.rlim_max
= RLIM_INFINITY
;
105 (void)setrlimit(RLIMIT_CPU
, &rlim
);
106 (void)setrlimit(RLIMIT_FSIZE
, &rlim
);
107 (void)setrlimit(RLIMIT_STACK
, &rlim
);
108 (void)setrlimit(RLIMIT_DATA
, &rlim
);
109 (void)setrlimit(RLIMIT_RSS
, &rlim
);
111 /* Don't drop core (not really necessary, but GP's). */
112 rlim
.rlim_cur
= rlim
.rlim_max
= 0;
113 (void)setrlimit(RLIMIT_CORE
, &rlim
);
115 /* Turn off signals. */
116 (void)signal(SIGALRM
, SIG_IGN
);
117 (void)signal(SIGHUP
, SIG_IGN
);
118 (void)signal(SIGINT
, SIG_IGN
);
119 (void)signal(SIGPIPE
, SIG_IGN
);
120 (void)signal(SIGQUIT
, SIG_IGN
);
121 (void)signal(SIGTERM
, SIG_IGN
);
122 (void)signal(SIGCONT
, pw_cont
);
124 /* Create with exact permissions. */
132 * If the master password file doesn't exist, the system is hosed.
133 * Might as well try to build one. Set the close-on-exec bit so
134 * that users can't get at the encrypted passwords while editing.
135 * Open should allow flock'ing the file; see 4.4BSD. XXX
137 lockfd
= open(_PATH_MASTERPASSWD
, O_RDONLY
, 0);
138 if (lockfd
< 0 || fcntl(lockfd
, F_SETFD
, 1) == -1)
139 err(1, "%s", _PATH_MASTERPASSWD
);
140 if (flock(lockfd
, LOCK_EX
|LOCK_NB
))
141 errx(1, "the password db file is busy");
148 static char path
[MAXPATHLEN
] = _PATH_MASTERPASSWD
;
152 if (p
= strrchr(path
, '/'))
156 strcpy(p
, "pw.XXXXXX");
157 if ((fd
= mkstemp(path
)) == -1)
169 warnx("rebuilding the database...");
170 (void)fflush(stderr
);
171 if (!(pid
= vfork())) {
172 execl(_PATH_PWD_MKDB
, "pwd_mkdb", "-p", tempname
, NULL
);
173 pw_error(_PATH_PWD_MKDB
, 1, 1);
175 pid
= waitpid(pid
, &pstat
, 0);
176 if (pid
== -1 || !WIFEXITED(pstat
) || WEXITSTATUS(pstat
) != 0)
189 if (!(editor
= getenv("EDITOR")))
191 if (p
= strrchr(editor
, '/'))
196 if (!(editpid
= vfork())) {
198 (void)setgid(getgid());
199 (void)setuid(getuid());
201 execlp(editor
, p
, tempname
, NULL
);
205 editpid
= waitpid(editpid
, (int *)&pstat
, WUNTRACED
);
207 pw_error(editor
, 1, 1);
208 else if (WIFSTOPPED(pstat
))
209 raise(WSTOPSIG(pstat
));
210 else if (WIFEXITED(pstat
) && WEXITSTATUS(pstat
) == 0)
213 pw_error(editor
, 1, 1);
223 (void)printf("re-edit the password file? [y]: ");
224 (void)fflush(stdout
);
226 if (c
!= EOF
&& c
!= '\n')
227 while (getchar() != '\n');
229 pw_error(NULL
, 0, 0);
233 pw_error(name
, err
, eval
)
240 warnx("%s: unchanged", _PATH_MASTERPASSWD
);
241 (void)unlink(tempname
);