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