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