1*8a16b7a1SPedro F. Giffuni /*-
2*8a16b7a1SPedro F. Giffuni * SPDX-License-Identifier: BSD-3-Clause
3*8a16b7a1SPedro F. Giffuni *
4dea673e9SRodney W. Grimes * Copyright (c) 1987, 1993, 1994
5dea673e9SRodney W. Grimes * The Regents of the University of California. All rights reserved.
6f1d05925SDag-Erling Smørgrav * Copyright (c) 2002 Networks Associates Technology, Inc.
7f1d05925SDag-Erling Smørgrav * All rights reserved.
8f1d05925SDag-Erling Smørgrav *
9f1d05925SDag-Erling Smørgrav * Portions of this software were developed for the FreeBSD Project by
10f1d05925SDag-Erling Smørgrav * ThinkSec AS and NAI Labs, the Security Research Division of Network
11f1d05925SDag-Erling Smørgrav * Associates, Inc. under DARPA/SPAWAR contract N66001-01-C-8035
12f1d05925SDag-Erling Smørgrav * ("CBOSS"), as part of the DARPA CHATS research program.
13dea673e9SRodney W. Grimes *
14dea673e9SRodney W. Grimes * Redistribution and use in source and binary forms, with or without
15dea673e9SRodney W. Grimes * modification, are permitted provided that the following conditions
16dea673e9SRodney W. Grimes * are met:
17dea673e9SRodney W. Grimes * 1. Redistributions of source code must retain the above copyright
18dea673e9SRodney W. Grimes * notice, this list of conditions and the following disclaimer.
19dea673e9SRodney W. Grimes * 2. Redistributions in binary form must reproduce the above copyright
20dea673e9SRodney W. Grimes * notice, this list of conditions and the following disclaimer in the
21dea673e9SRodney W. Grimes * documentation and/or other materials provided with the distribution.
22fbbd9655SWarner Losh * 3. Neither the name of the University nor the names of its contributors
23dea673e9SRodney W. Grimes * may be used to endorse or promote products derived from this software
24dea673e9SRodney W. Grimes * without specific prior written permission.
25dea673e9SRodney W. Grimes *
26dea673e9SRodney W. Grimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
27dea673e9SRodney W. Grimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
28dea673e9SRodney W. Grimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
29dea673e9SRodney W. Grimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
30dea673e9SRodney W. Grimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
31dea673e9SRodney W. Grimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
32dea673e9SRodney W. Grimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
33dea673e9SRodney W. Grimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
34dea673e9SRodney W. Grimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
35dea673e9SRodney W. Grimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
36dea673e9SRodney W. Grimes * SUCH DAMAGE.
37dea673e9SRodney W. Grimes */
38dea673e9SRodney W. Grimes
39dea673e9SRodney W. Grimes #include <sys/types.h>
40dea673e9SRodney W. Grimes #include <sys/stat.h>
41dea673e9SRodney W. Grimes
42dea673e9SRodney W. Grimes #include <err.h>
43dea673e9SRodney W. Grimes #include <pwd.h>
44dea673e9SRodney W. Grimes #include <stdio.h>
45dea673e9SRodney W. Grimes #include <stdlib.h>
46dea673e9SRodney W. Grimes #include <string.h>
47dea673e9SRodney W. Grimes #include <unistd.h>
48dea673e9SRodney W. Grimes
49f1d05925SDag-Erling Smørgrav #include <libutil.h> /* must be after pwd.h */
50dea673e9SRodney W. Grimes
5193deb2aeSDag-Erling Smørgrav static void usage(void);
52dea673e9SRodney W. Grimes
53dea673e9SRodney W. Grimes int
main(int argc,char * argv[])5493deb2aeSDag-Erling Smørgrav main(int argc, char *argv[])
55dea673e9SRodney W. Grimes {
56f1d05925SDag-Erling Smørgrav const char *passwd_dir = NULL;
57f1d05925SDag-Erling Smørgrav int ch, pfd, tfd;
58f1d05925SDag-Erling Smørgrav char *line;
59f1d05925SDag-Erling Smørgrav size_t len;
60dea673e9SRodney W. Grimes
61af2d5f9bSSheldon Hearn while ((ch = getopt(argc, argv, "d:")) != -1)
62dea673e9SRodney W. Grimes switch (ch) {
63af2d5f9bSSheldon Hearn case 'd':
64f1d05925SDag-Erling Smørgrav passwd_dir = optarg;
65af2d5f9bSSheldon Hearn break;
66dea673e9SRodney W. Grimes case '?':
67dea673e9SRodney W. Grimes default:
68dea673e9SRodney W. Grimes usage();
69dea673e9SRodney W. Grimes }
70dea673e9SRodney W. Grimes
71dea673e9SRodney W. Grimes argc -= optind;
72dea673e9SRodney W. Grimes argv += optind;
73dea673e9SRodney W. Grimes
74dea673e9SRodney W. Grimes if (argc != 0)
75dea673e9SRodney W. Grimes usage();
76dea673e9SRodney W. Grimes
77f1d05925SDag-Erling Smørgrav if (pw_init(passwd_dir, NULL) == -1)
78f1d05925SDag-Erling Smørgrav err(1, "pw_init()");
79f1d05925SDag-Erling Smørgrav if ((pfd = pw_lock()) == -1) {
80f1d05925SDag-Erling Smørgrav pw_fini();
81f1d05925SDag-Erling Smørgrav err(1, "pw_lock()");
82f1d05925SDag-Erling Smørgrav }
83f1d05925SDag-Erling Smørgrav if ((tfd = pw_tmp(pfd)) == -1) {
84f1d05925SDag-Erling Smørgrav pw_fini();
85f1d05925SDag-Erling Smørgrav err(1, "pw_tmp()");
86f1d05925SDag-Erling Smørgrav }
87dea673e9SRodney W. Grimes (void)close(tfd);
882ece3ed4SPierre Beyssac /* Force umask for partial writes made in the edit phase */
892ece3ed4SPierre Beyssac (void)umask(077);
90dea673e9SRodney W. Grimes
91dea673e9SRodney W. Grimes for (;;) {
9224a45ad2SWarner Losh switch (pw_edit(0)) {
93f1d05925SDag-Erling Smørgrav case -1:
94f1d05925SDag-Erling Smørgrav pw_fini();
95f1d05925SDag-Erling Smørgrav err(1, "pw_edit()");
96f1d05925SDag-Erling Smørgrav case 0:
97f1d05925SDag-Erling Smørgrav pw_fini();
98f1d05925SDag-Erling Smørgrav errx(0, "no changes made");
99f1d05925SDag-Erling Smørgrav default:
100dea673e9SRodney W. Grimes break;
101dea673e9SRodney W. Grimes }
102f1d05925SDag-Erling Smørgrav if (pw_mkdb(NULL) == 0) {
103f1d05925SDag-Erling Smørgrav pw_fini();
104f1d05925SDag-Erling Smørgrav errx(0, "password list updated");
105f1d05925SDag-Erling Smørgrav }
106f1d05925SDag-Erling Smørgrav printf("re-edit the password file? ");
107f1d05925SDag-Erling Smørgrav fflush(stdout);
108f1d05925SDag-Erling Smørgrav if ((line = fgetln(stdin, &len)) == NULL) {
109f1d05925SDag-Erling Smørgrav pw_fini();
110f1d05925SDag-Erling Smørgrav err(1, "fgetln()");
111f1d05925SDag-Erling Smørgrav }
112f1d05925SDag-Erling Smørgrav if (len > 0 && (*line == 'N' || *line == 'n'))
113f1d05925SDag-Erling Smørgrav break;
114f1d05925SDag-Erling Smørgrav }
115f1d05925SDag-Erling Smørgrav pw_fini();
116dea673e9SRodney W. Grimes exit(0);
117dea673e9SRodney W. Grimes }
118dea673e9SRodney W. Grimes
11993deb2aeSDag-Erling Smørgrav static void
usage(void)12093deb2aeSDag-Erling Smørgrav usage(void)
121dea673e9SRodney W. Grimes {
122dea673e9SRodney W. Grimes
123af2d5f9bSSheldon Hearn (void)fprintf(stderr, "usage: vipw [-d directory]\n");
124dea673e9SRodney W. Grimes exit(1);
125dea673e9SRodney W. Grimes }
126