Also split open_files and close_files out of main().
New global variables use_system_pw_file and use_system_spw_file
This commit is contained in:
parent
6912ac253a
commit
ef2c12e560
@ -1,7 +1,8 @@
|
|||||||
2008-01-01 Nicolas François <nicolas.francois@centraliens.net>
|
2008-01-01 Nicolas François <nicolas.francois@centraliens.net>
|
||||||
|
|
||||||
* src/pwck.c: Split process_flags() out of main(). New global
|
* src/pwck.c: Split process_flags(), open_files(), and
|
||||||
variables is_shadow, sort_mode.
|
close_files() out of main(). New global variables is_shadow,
|
||||||
|
sort_mode, use_system_pw_file, and use_system_spw_file.
|
||||||
|
|
||||||
2008-01-01 Nicolas François <nicolas.francois@centraliens.net>
|
2008-01-01 Nicolas François <nicolas.francois@centraliens.net>
|
||||||
|
|
||||||
|
168
src/pwck.c
168
src/pwck.c
@ -66,7 +66,9 @@ extern struct commonio_entry *__spw_get_head (void);
|
|||||||
|
|
||||||
static char *Prog;
|
static char *Prog;
|
||||||
static const char *pwd_file = PASSWD_FILE;
|
static const char *pwd_file = PASSWD_FILE;
|
||||||
|
static int use_system_pw_file = 1;
|
||||||
static const char *spw_file = SHADOW_FILE;
|
static const char *spw_file = SHADOW_FILE;
|
||||||
|
static int use_system_spw_file = 1;
|
||||||
|
|
||||||
static int is_shadow = 0;
|
static int is_shadow = 0;
|
||||||
|
|
||||||
@ -78,6 +80,8 @@ static int quiet = 0; /* don't report warnings, only errors */
|
|||||||
/* local function prototypes */
|
/* local function prototypes */
|
||||||
static void usage (void);
|
static void usage (void);
|
||||||
static void process_flags (int argc, char **argv);
|
static void process_flags (int argc, char **argv);
|
||||||
|
static void open_files (void);
|
||||||
|
static void close_files (int changed);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* usage - print syntax message and exit
|
* usage - print syntax message and exit
|
||||||
@ -145,6 +149,96 @@ static void process_flags (int argc, char **argv)
|
|||||||
is_shadow = spw_file_present ();
|
is_shadow = spw_file_present ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* open_files - open the shadow database
|
||||||
|
*
|
||||||
|
* In read-only mode, the databases are not locked and are opened
|
||||||
|
* only for reading.
|
||||||
|
*/
|
||||||
|
static void open_files (void)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* Lock the files if we aren't in "read-only" mode
|
||||||
|
*/
|
||||||
|
if (!read_only) {
|
||||||
|
if (!pw_lock ()) {
|
||||||
|
fprintf (stderr, _("%s: cannot lock file %s\n"),
|
||||||
|
Prog, pwd_file);
|
||||||
|
if (use_system_pw_file)
|
||||||
|
SYSLOG ((LOG_WARN, "cannot lock %s", pwd_file));
|
||||||
|
closelog ();
|
||||||
|
exit (E_CANTLOCK);
|
||||||
|
}
|
||||||
|
if (is_shadow && !spw_lock ()) {
|
||||||
|
fprintf (stderr, _("%s: cannot lock file %s\n"),
|
||||||
|
Prog, spw_file);
|
||||||
|
if (use_system_spw_file)
|
||||||
|
SYSLOG ((LOG_WARN, "cannot lock %s", spw_file));
|
||||||
|
closelog ();
|
||||||
|
exit (E_CANTLOCK);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Open the files. Use O_RDONLY if we are in read_only mode, O_RDWR
|
||||||
|
* otherwise.
|
||||||
|
*/
|
||||||
|
if (!pw_open (read_only ? O_RDONLY : O_RDWR)) {
|
||||||
|
fprintf (stderr, _("%s: cannot open file %s\n"),
|
||||||
|
Prog, pwd_file);
|
||||||
|
if (use_system_pw_file)
|
||||||
|
SYSLOG ((LOG_WARN, "cannot open %s", pwd_file));
|
||||||
|
closelog ();
|
||||||
|
exit (E_CANTOPEN);
|
||||||
|
}
|
||||||
|
if (is_shadow && !spw_open (read_only ? O_RDONLY : O_RDWR)) {
|
||||||
|
fprintf (stderr, _("%s: cannot open file %s\n"),
|
||||||
|
Prog, spw_file);
|
||||||
|
if (use_system_spw_file)
|
||||||
|
SYSLOG ((LOG_WARN, "cannot open %s", spw_file));
|
||||||
|
closelog ();
|
||||||
|
exit (E_CANTOPEN);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* close_files - close and unlock the password/shadow databases
|
||||||
|
*
|
||||||
|
* If changed is not set, the databases are not closed, and no
|
||||||
|
* changes are committed in the databases. The databases are
|
||||||
|
* unlocked anyway.
|
||||||
|
*/
|
||||||
|
static void close_files (int changed)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* All done. If there were no change we can just abandon any
|
||||||
|
* changes to the files.
|
||||||
|
*/
|
||||||
|
if (changed) {
|
||||||
|
if (!pw_close ()) {
|
||||||
|
fprintf (stderr, _("%s: cannot update file %s\n"),
|
||||||
|
Prog, pwd_file);
|
||||||
|
SYSLOG ((LOG_WARN, "cannot update %s", pwd_file));
|
||||||
|
closelog ();
|
||||||
|
exit (E_CANTUPDATE);
|
||||||
|
}
|
||||||
|
if (is_shadow && !spw_close ()) {
|
||||||
|
fprintf (stderr, _("%s: cannot update file %s\n"),
|
||||||
|
Prog, spw_file);
|
||||||
|
SYSLOG ((LOG_WARN, "cannot update %s", spw_file));
|
||||||
|
closelog ();
|
||||||
|
exit (E_CANTUPDATE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Don't be anti-social - unlock the files when you're done.
|
||||||
|
*/
|
||||||
|
if (is_shadow)
|
||||||
|
spw_unlock ();
|
||||||
|
(void) pw_unlock ();
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* pwck - verify password file integrity
|
* pwck - verify password file integrity
|
||||||
*/
|
*/
|
||||||
@ -172,53 +266,13 @@ int main (int argc, char **argv)
|
|||||||
/* Parse the command line arguments */
|
/* Parse the command line arguments */
|
||||||
process_flags (argc, argv);
|
process_flags (argc, argv);
|
||||||
|
|
||||||
/*
|
open_files ();
|
||||||
* Lock the files if we aren't in "read-only" mode
|
|
||||||
*/
|
|
||||||
if (!read_only) {
|
|
||||||
if (!pw_lock ()) {
|
|
||||||
fprintf (stderr, _("%s: cannot lock file %s\n"),
|
|
||||||
Prog, pwd_file);
|
|
||||||
if (optind == argc)
|
|
||||||
SYSLOG ((LOG_WARN, "cannot lock %s", pwd_file));
|
|
||||||
closelog ();
|
|
||||||
exit (E_CANTLOCK);
|
|
||||||
}
|
|
||||||
if (is_shadow && !spw_lock ()) {
|
|
||||||
fprintf (stderr, _("%s: cannot lock file %s\n"),
|
|
||||||
Prog, spw_file);
|
|
||||||
if (optind == argc)
|
|
||||||
SYSLOG ((LOG_WARN, "cannot lock %s", spw_file));
|
|
||||||
closelog ();
|
|
||||||
exit (E_CANTLOCK);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Open the files. Use O_RDONLY if we are in read_only mode, O_RDWR
|
|
||||||
* otherwise.
|
|
||||||
*/
|
|
||||||
if (!pw_open (read_only ? O_RDONLY : O_RDWR)) {
|
|
||||||
fprintf (stderr, _("%s: cannot open file %s\n"),
|
|
||||||
Prog, pwd_file);
|
|
||||||
if (optind == argc)
|
|
||||||
SYSLOG ((LOG_WARN, "cannot open %s", pwd_file));
|
|
||||||
closelog ();
|
|
||||||
exit (E_CANTOPEN);
|
|
||||||
}
|
|
||||||
if (is_shadow && !spw_open (read_only ? O_RDONLY : O_RDWR)) {
|
|
||||||
fprintf (stderr, _("%s: cannot open file %s\n"),
|
|
||||||
Prog, spw_file);
|
|
||||||
if (optind == argc)
|
|
||||||
SYSLOG ((LOG_WARN, "cannot open %s", spw_file));
|
|
||||||
closelog ();
|
|
||||||
exit (E_CANTOPEN);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (sort_mode) {
|
if (sort_mode) {
|
||||||
pw_sort ();
|
pw_sort ();
|
||||||
if (is_shadow)
|
if (is_shadow)
|
||||||
spw_sort ();
|
spw_sort ();
|
||||||
|
changed = 1;
|
||||||
goto write_and_bye;
|
goto write_and_bye;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -544,34 +598,8 @@ int main (int argc, char **argv)
|
|||||||
|
|
||||||
shadow_done:
|
shadow_done:
|
||||||
|
|
||||||
/*
|
write_and_bye:
|
||||||
* All done. If there were no change we can just abandon any
|
close_files (changed);
|
||||||
* changes to the files.
|
|
||||||
*/
|
|
||||||
if (changed) {
|
|
||||||
write_and_bye:
|
|
||||||
if (!pw_close ()) {
|
|
||||||
fprintf (stderr, _("%s: cannot update file %s\n"),
|
|
||||||
Prog, pwd_file);
|
|
||||||
SYSLOG ((LOG_WARN, "cannot update %s", pwd_file));
|
|
||||||
closelog ();
|
|
||||||
exit (E_CANTUPDATE);
|
|
||||||
}
|
|
||||||
if (is_shadow && !spw_close ()) {
|
|
||||||
fprintf (stderr, _("%s: cannot update file %s\n"),
|
|
||||||
Prog, spw_file);
|
|
||||||
SYSLOG ((LOG_WARN, "cannot update %s", spw_file));
|
|
||||||
closelog ();
|
|
||||||
exit (E_CANTUPDATE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Don't be anti-social - unlock the files when you're done.
|
|
||||||
*/
|
|
||||||
if (is_shadow)
|
|
||||||
spw_unlock ();
|
|
||||||
(void) pw_unlock ();
|
|
||||||
|
|
||||||
nscd_flush_cache ("passwd");
|
nscd_flush_cache ("passwd");
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user