From 79157cbad87f42cdc2068d72e798488572c68bb2 Mon Sep 17 00:00:00 2001 From: Serge Hallyn Date: Sun, 28 Nov 2021 17:37:53 -0600 Subject: [PATCH] Make shadow_logfd and Prog not extern Closes #444 Closes #465 Signed-off-by: Serge Hallyn --- lib/Makefile.am | 2 ++ lib/commonio.c | 1 + lib/encrypt.c | 1 + lib/getdef.c | 1 + lib/nscd.c | 1 + lib/nss.c | 1 + lib/prototypes.h | 3 --- lib/run_part.c | 1 + lib/selinux.c | 2 ++ lib/semanage.c | 1 + lib/shadowlog.c | 28 ++++++++++++++++++++ lib/shadowlog.h | 41 ++++++++++++++++++++++++++++++ lib/shadowlog_internal.h | 2 ++ lib/spawn.c | 2 ++ lib/sssd.c | 2 ++ lib/tcbfuncs.c | 2 ++ libmisc/addgrps.c | 2 ++ libmisc/audit_help.c | 3 ++- libmisc/chowntty.c | 2 ++ libmisc/cleanup_group.c | 25 +++++++++--------- libmisc/cleanup_user.c | 17 +++++++------ libmisc/copydir.c | 8 +++--- libmisc/env.c | 3 ++- libmisc/find_new_gid.c | 37 ++++++++++++++------------- libmisc/find_new_sub_gids.c | 9 ++++--- libmisc/find_new_sub_uids.c | 9 ++++--- libmisc/find_new_uid.c | 37 ++++++++++++++------------- libmisc/gettime.c | 2 ++ libmisc/idmapping.c | 41 +++++++++++++++--------------- libmisc/limits.c | 3 ++- libmisc/pam_pass.c | 2 ++ libmisc/pam_pass_non_interactive.c | 19 +++++++------- libmisc/prefix_flag.c | 13 +++++----- libmisc/pwdcheck.c | 3 ++- libmisc/root_flag.c | 29 +++++++++++---------- libmisc/salt.c | 7 ++--- libmisc/setupenv.c | 3 ++- libmisc/user_busy.c | 13 +++++----- libmisc/xgetXXbyYY.c | 7 ++--- libmisc/xmalloc.c | 5 ++-- libsubid/api.c | 8 +++--- src/chage.c | 5 ++-- src/check_subid_range.c | 5 ++-- src/chfn.c | 5 ++-- src/chgpasswd.c | 5 ++-- src/chpasswd.c | 5 ++-- src/chsh.c | 5 ++-- src/expiry.c | 5 ++-- src/faillog.c | 5 ++-- src/free_subid_range.c | 5 ++-- src/get_subid_owners.c | 5 ++-- src/getsubids.c | 5 ++-- src/gpasswd.c | 5 ++-- src/groupadd.c | 5 ++-- src/groupdel.c | 5 ++-- src/groupmems.c | 5 ++-- src/groupmod.c | 5 ++-- src/groups.c | 5 ++-- src/grpck.c | 5 ++-- src/grpconv.c | 5 ++-- src/grpunconv.c | 5 ++-- src/lastlog.c | 5 ++-- src/login.c | 5 ++-- src/logoutd.c | 5 ++-- src/new_subid_range.c | 5 ++-- src/newgidmap.c | 5 ++-- src/newgrp.c | 5 ++-- src/newuidmap.c | 5 ++-- src/newusers.c | 5 ++-- src/passwd.c | 5 ++-- src/pwck.c | 5 ++-- src/pwconv.c | 5 ++-- src/pwunconv.c | 5 ++-- src/su.c | 5 ++-- src/sulogin.c | 5 ++-- src/useradd.c | 5 ++-- src/userdel.c | 5 ++-- src/usermod.c | 5 ++-- src/vipw.c | 5 ++-- 79 files changed, 371 insertions(+), 217 deletions(-) create mode 100644 lib/shadowlog.c create mode 100644 lib/shadowlog.h create mode 100644 lib/shadowlog_internal.h diff --git a/lib/Makefile.am b/lib/Makefile.am index 582f843c5..7421083fb 100644 --- a/lib/Makefile.am +++ b/lib/Makefile.am @@ -36,6 +36,8 @@ libshadow_la_SOURCES = \ nss.c \ nscd.c \ nscd.h \ + shadowlog.c \ + shadowlog.h \ sssd.c \ sssd.h \ pam_defs.h \ diff --git a/lib/commonio.c b/lib/commonio.c index 3caddf1a5..10317b0e1 100644 --- a/lib/commonio.c +++ b/lib/commonio.c @@ -51,6 +51,7 @@ #endif /* WITH_TCB */ #include "prototypes.h" #include "commonio.h" +#include "shadowlog_internal.h" /* local function prototypes */ static int lrename (const char *, const char *); diff --git a/lib/encrypt.c b/lib/encrypt.c index 66c52f2d8..94c72fb56 100644 --- a/lib/encrypt.c +++ b/lib/encrypt.c @@ -39,6 +39,7 @@ #include "prototypes.h" #include "defines.h" +#include "shadowlog_internal.h" /*@exposed@*//*@null@*/char *pw_encrypt (const char *clear, const char *salt) { diff --git a/lib/getdef.c b/lib/getdef.c index 80eb18c4f..596b23f71 100644 --- a/lib/getdef.c +++ b/lib/getdef.c @@ -44,6 +44,7 @@ #include #endif #include "getdef.h" +#include "shadowlog_internal.h" /* * A configuration item definition. */ diff --git a/lib/nscd.c b/lib/nscd.c index 397212e22..693b40712 100644 --- a/lib/nscd.c +++ b/lib/nscd.c @@ -10,6 +10,7 @@ #include "defines.h" #include "prototypes.h" #include "nscd.h" +#include "shadowlog_internal.h" #define MSG_NSCD_FLUSH_CACHE_FAILED "%s: Failed to flush the nscd cache.\n" diff --git a/lib/nss.c b/lib/nss.c index 7c082758e..af3e95ac8 100644 --- a/lib/nss.c +++ b/lib/nss.c @@ -8,6 +8,7 @@ #include #include "prototypes.h" #include "../libsubid/subid.h" +#include "shadowlog_internal.h" #define NSSWITCH "/etc/nsswitch.conf" diff --git a/lib/prototypes.h b/lib/prototypes.h index b697e0ecc..535c671fc 100644 --- a/lib/prototypes.h +++ b/lib/prototypes.h @@ -59,9 +59,6 @@ #include "defines.h" #include "commonio.h" -extern /*@observer@*/ const char *Prog; /* Program name showed in error messages */ -extern FILE *shadow_logfd; /* file descripter to which error messages are printed */ - /* addgrps.c */ #if defined (HAVE_SETGROUPS) && ! defined (USE_PAM) extern int add_groups (const char *); diff --git a/lib/run_part.c b/lib/run_part.c index f69da8877..1ce06be04 100644 --- a/lib/run_part.c +++ b/lib/run_part.c @@ -8,6 +8,7 @@ #include #include #include +#include "shadowlog_internal.h" int run_part (char *script_path, char *name, char *action) { diff --git a/lib/selinux.c b/lib/selinux.c index b075d4c04..890fee4fb 100644 --- a/lib/selinux.c +++ b/lib/selinux.c @@ -38,6 +38,8 @@ #include #include "prototypes.h" +#include "shadowlog_internal.h" + static bool selinux_checked = false; static bool selinux_enabled; static /*@null@*/struct selabel_handle *selabel_hnd = NULL; diff --git a/lib/semanage.c b/lib/semanage.c index a5bf92185..27b1d5606 100644 --- a/lib/semanage.c +++ b/lib/semanage.c @@ -43,6 +43,7 @@ #include #include "prototypes.h" +#include "shadowlog_internal.h" #ifndef DEFAULT_SERANGE #define DEFAULT_SERANGE "s0" diff --git a/lib/shadowlog.c b/lib/shadowlog.c new file mode 100644 index 000000000..5feaef2a7 --- /dev/null +++ b/lib/shadowlog.c @@ -0,0 +1,28 @@ +#include "shadowlog.h" + +#include "lib/shadowlog_internal.h" + +void log_set_progname(const char *progname) +{ + Prog = progname; +} + +const char *log_get_progname(void) +{ + return Prog; +} + +void log_set_logfd(FILE *fd) +{ + if (NULL != fd) + shadow_logfd = fd; + else + shadow_logfd = stderr; +} + +FILE *log_get_logfd(void) +{ + if (shadow_logfd != NULL) + return shadow_logfd; + return stderr; +} diff --git a/lib/shadowlog.h b/lib/shadowlog.h new file mode 100644 index 000000000..bf8be8557 --- /dev/null +++ b/lib/shadowlog.h @@ -0,0 +1,41 @@ +/* + * Copyright (c) 2021 , Serge Hallyn + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. The name of the copyright holders or contributors may not be used to + * endorse or promote products derived from this software without + * specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A + * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +/* $Id$ */ +#ifndef _LOG_H +#define _LOG_H +#include + +extern void log_set_progname(const char *); +extern const char *log_get_progname(void); +extern void log_set_logfd(FILE *fd); +extern FILE *log_get_logfd(void); +extern void log_dolog(char *, ...); + +#endif diff --git a/lib/shadowlog_internal.h b/lib/shadowlog_internal.h new file mode 100644 index 000000000..cf96fae02 --- /dev/null +++ b/lib/shadowlog_internal.h @@ -0,0 +1,2 @@ +const char *Prog; /* Program name showed in error messages */ +FILE *shadow_logfd; /* file descripter to which error messages are printed */ diff --git a/lib/spawn.c b/lib/spawn.c index c53742ccd..6983e28f6 100644 --- a/lib/spawn.c +++ b/lib/spawn.c @@ -38,6 +38,8 @@ #include "exitcodes.h" #include "prototypes.h" +#include "shadowlog_internal.h" + int run_command (const char *cmd, const char *argv[], /*@null@*/const char *envp[], /*@out@*/int *status) { diff --git a/lib/sssd.c b/lib/sssd.c index f864ce689..f66fd88a8 100644 --- a/lib/sssd.c +++ b/lib/sssd.c @@ -11,6 +11,8 @@ #include "prototypes.h" #include "sssd.h" +#include "shadowlog_internal.h" + #define MSG_SSSD_FLUSH_CACHE_FAILED "%s: Failed to flush the sssd cache." int sssd_flush_cache (int dbflags) diff --git a/lib/tcbfuncs.c b/lib/tcbfuncs.c index b68b15b32..8bcc5dc28 100644 --- a/lib/tcbfuncs.c +++ b/lib/tcbfuncs.c @@ -38,6 +38,8 @@ #include "shadowio.h" #include "tcbfuncs.h" +#include "shadowlog_internal.h" + #define SHADOWTCB_HASH_BY 1000 #define SHADOWTCB_LOCK_SUFFIX ".lock" diff --git a/libmisc/addgrps.c b/libmisc/addgrps.c index 76c172a5b..084369699 100644 --- a/libmisc/addgrps.c +++ b/libmisc/addgrps.c @@ -40,6 +40,7 @@ #include #include #include +#include "shadowlog.h" #ident "$Id$" @@ -58,6 +59,7 @@ int add_groups (const char *list) char *token; char buf[1024]; int ret; + FILE *shadow_logfd = log_get_logfd(); if (strlen (list) >= sizeof (buf)) { errno = EINVAL; diff --git a/libmisc/audit_help.c b/libmisc/audit_help.c index c5cd87d65..4355cbacb 100644 --- a/libmisc/audit_help.c +++ b/libmisc/audit_help.c @@ -45,6 +45,7 @@ #include #include #include "prototypes.h" +#include "shadowlog.h" int audit_fd; void audit_help_open (void) @@ -59,7 +60,7 @@ void audit_help_open (void) return; } (void) fputs (_("Cannot open audit interface - aborting.\n"), - shadow_logfd); + log_get_logfd()); exit (EXIT_FAILURE); } } diff --git a/libmisc/chowntty.c b/libmisc/chowntty.c index a42ab6220..001e40a5a 100644 --- a/libmisc/chowntty.c +++ b/libmisc/chowntty.c @@ -43,6 +43,7 @@ #include "defines.h" #include #include "getdef.h" +#include "shadowlog.h" /* * chown_tty() sets the login tty to be owned by the new user ID @@ -75,6 +76,7 @@ void chown_tty (const struct passwd *info) if ( (fchown (STDIN_FILENO, info->pw_uid, gid) != 0) || (fchmod (STDIN_FILENO, (mode_t)getdef_num ("TTYPERM", 0600)) != 0)) { int err = errno; + FILE *shadow_logfd = log_get_logfd(); fprintf (shadow_logfd, _("Unable to change owner or mode of tty stdin: %s"), diff --git a/libmisc/cleanup_group.c b/libmisc/cleanup_group.c index a1233eac4..b1889764d 100644 --- a/libmisc/cleanup_group.c +++ b/libmisc/cleanup_group.c @@ -36,6 +36,7 @@ #include "groupio.h" #include "sgroupio.h" #include "prototypes.h" +#include "shadowlog.h" /* * cleanup_report_add_group - Report failure to add a group to the system @@ -48,7 +49,7 @@ void cleanup_report_add_group (void *group_name) SYSLOG ((LOG_ERR, "failed to add group %s", name)); #ifdef WITH_AUDIT - audit_logger (AUDIT_ADD_GROUP, Prog, + audit_logger (AUDIT_ADD_GROUP, log_get_progname(), "", name, AUDIT_NO_ID, SHADOW_AUDIT_FAILURE); @@ -66,7 +67,7 @@ void cleanup_report_del_group (void *group_name) SYSLOG ((LOG_ERR, "failed to remove group %s", name)); #ifdef WITH_AUDIT - audit_logger (AUDIT_DEL_GROUP, Prog, + audit_logger (AUDIT_DEL_GROUP, log_get_progname(), "", name, AUDIT_NO_ID, SHADOW_AUDIT_FAILURE); @@ -83,7 +84,7 @@ void cleanup_report_mod_group (void *cleanup_info) gr_dbname (), info->action)); #ifdef WITH_AUDIT - audit_logger (AUDIT_USER_ACCT, Prog, + audit_logger (AUDIT_USER_ACCT, log_get_progname(), info->audit_msg, info->name, AUDIT_NO_ID, SHADOW_AUDIT_FAILURE); @@ -101,7 +102,7 @@ void cleanup_report_mod_gshadow (void *cleanup_info) sgr_dbname (), info->action)); #ifdef WITH_AUDIT - audit_logger (AUDIT_USER_ACCT, Prog, + audit_logger (AUDIT_USER_ACCT, log_get_progname(), info->audit_msg, info->name, AUDIT_NO_ID, SHADOW_AUDIT_FAILURE); @@ -121,7 +122,7 @@ void cleanup_report_add_group_group (void *group_name) SYSLOG ((LOG_ERR, "failed to add group %s to %s", name, gr_dbname ())); #ifdef WITH_AUDIT - audit_logger (AUDIT_ADD_GROUP, Prog, + audit_logger (AUDIT_ADD_GROUP, log_get_progname(), "adding group to /etc/group", name, AUDIT_NO_ID, SHADOW_AUDIT_FAILURE); @@ -141,7 +142,7 @@ void cleanup_report_add_group_gshadow (void *group_name) SYSLOG ((LOG_ERR, "failed to add group %s to %s", name, sgr_dbname ())); #ifdef WITH_AUDIT - audit_logger (AUDIT_ADD_GROUP, Prog, + audit_logger (AUDIT_ADD_GROUP, log_get_progname(), "adding group to /etc/gshadow", name, AUDIT_NO_ID, SHADOW_AUDIT_FAILURE); @@ -164,7 +165,7 @@ void cleanup_report_del_group_group (void *group_name) "failed to remove group %s from %s", name, gr_dbname ())); #ifdef WITH_AUDIT - audit_logger (AUDIT_ADD_GROUP, Prog, + audit_logger (AUDIT_ADD_GROUP, log_get_progname(), "removing group from /etc/group", name, AUDIT_NO_ID, SHADOW_AUDIT_FAILURE); @@ -187,7 +188,7 @@ void cleanup_report_del_group_gshadow (void *group_name) "failed to remove group %s from %s", name, sgr_dbname ())); #ifdef WITH_AUDIT - audit_logger (AUDIT_ADD_GROUP, Prog, + audit_logger (AUDIT_ADD_GROUP, log_get_progname(), "removing group from /etc/gshadow", name, AUDIT_NO_ID, SHADOW_AUDIT_FAILURE); @@ -203,9 +204,9 @@ void cleanup_report_del_group_gshadow (void *group_name) void cleanup_unlock_group (unused void *arg) { if (gr_unlock () == 0) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: failed to unlock %s\n"), - Prog, gr_dbname ()); + log_get_progname(), gr_dbname ()); SYSLOG ((LOG_ERR, "failed to unlock %s", gr_dbname ())); #ifdef WITH_AUDIT audit_logger_message ("unlocking group file", @@ -223,9 +224,9 @@ void cleanup_unlock_group (unused void *arg) void cleanup_unlock_gshadow (unused void *arg) { if (sgr_unlock () == 0) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: failed to unlock %s\n"), - Prog, sgr_dbname ()); + log_get_progname(), sgr_dbname ()); SYSLOG ((LOG_ERR, "failed to unlock %s", sgr_dbname ())); #ifdef WITH_AUDIT audit_logger_message ("unlocking gshadow file", diff --git a/libmisc/cleanup_user.c b/libmisc/cleanup_user.c index 7422846a7..d943f1720 100644 --- a/libmisc/cleanup_user.c +++ b/libmisc/cleanup_user.c @@ -36,6 +36,7 @@ #include "pwio.h" #include "shadowio.h" #include "prototypes.h" +#include "shadowlog.h" /* * cleanup_report_add_user - Report failure to add an user to the system @@ -48,7 +49,7 @@ void cleanup_report_add_user (void *user_name) SYSLOG ((LOG_ERR, "failed to add user %s", name)); #ifdef WITH_AUDIT - audit_logger (AUDIT_ADD_USER, Prog, + audit_logger (AUDIT_ADD_USER, log_get_progname(), "", name, AUDIT_NO_ID, SHADOW_AUDIT_FAILURE); @@ -65,7 +66,7 @@ void cleanup_report_mod_passwd (void *cleanup_info) pw_dbname (), info->action)); #ifdef WITH_AUDIT - audit_logger (AUDIT_USER_ACCT, Prog, + audit_logger (AUDIT_USER_ACCT, log_get_progname(), info->audit_msg, info->name, AUDIT_NO_ID, SHADOW_AUDIT_FAILURE); @@ -85,7 +86,7 @@ void cleanup_report_add_user_passwd (void *user_name) SYSLOG ((LOG_ERR, "failed to add user %s to %s", name, pw_dbname ())); #ifdef WITH_AUDIT - audit_logger (AUDIT_ADD_USER, Prog, + audit_logger (AUDIT_ADD_USER, log_get_progname(), "adding user to /etc/passwd", name, AUDIT_NO_ID, SHADOW_AUDIT_FAILURE); @@ -105,7 +106,7 @@ void cleanup_report_add_user_shadow (void *user_name) SYSLOG ((LOG_ERR, "failed to add user %s to %s", name, spw_dbname ())); #ifdef WITH_AUDIT - audit_logger (AUDIT_ADD_USER, Prog, + audit_logger (AUDIT_ADD_USER, log_get_progname(), "adding user to /etc/shadow", name, AUDIT_NO_ID, SHADOW_AUDIT_FAILURE); @@ -120,9 +121,9 @@ void cleanup_report_add_user_shadow (void *user_name) void cleanup_unlock_passwd (unused void *arg) { if (pw_unlock () == 0) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: failed to unlock %s\n"), - Prog, pw_dbname ()); + log_get_progname(), pw_dbname ()); SYSLOG ((LOG_ERR, "failed to unlock %s", pw_dbname ())); #ifdef WITH_AUDIT audit_logger_message ("unlocking passwd file", @@ -139,9 +140,9 @@ void cleanup_unlock_passwd (unused void *arg) void cleanup_unlock_shadow (unused void *arg) { if (spw_unlock () == 0) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: failed to unlock %s\n"), - Prog, spw_dbname ()); + log_get_progname(), spw_dbname ()); SYSLOG ((LOG_ERR, "failed to unlock %s", spw_dbname ())); #ifdef WITH_AUDIT audit_logger_message ("unlocking shadow file", diff --git a/libmisc/copydir.c b/libmisc/copydir.c index 66dc79204..f2130bcac 100644 --- a/libmisc/copydir.c +++ b/libmisc/copydir.c @@ -55,6 +55,7 @@ #ifdef WITH_ATTR #include #endif /* WITH_ATTR */ +#include "shadowlog.h" static /*@null@*/const char *src_orig; @@ -116,6 +117,7 @@ static int fchown_if_needed (int fdst, const struct stat *statp, static void error_acl (struct error_context *ctx, const char *fmt, ...) { va_list ap; + FILE *shadow_logfd = log_get_logfd(); /* ignore the case when destination does not support ACLs * or extended attributes */ @@ -125,7 +127,7 @@ static void error_acl (struct error_context *ctx, const char *fmt, ...) } va_start (ap, fmt); - (void) fprintf (shadow_logfd, _("%s: "), Prog); + (void) fprintf (shadow_logfd, _("%s: "), log_get_progname()); if (vfprintf (shadow_logfd, fmt, ap) != 0) { (void) fputs (_(": "), shadow_logfd); } @@ -248,9 +250,9 @@ int copy_tree (const char *src_root, const char *dst_root, } if (!S_ISDIR (sb.st_mode)) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), "%s: %s is not a directory", - Prog, src_root); + log_get_progname(), src_root); return -1; } diff --git a/libmisc/env.c b/libmisc/env.c index 47a555843..357b62bc9 100644 --- a/libmisc/env.c +++ b/libmisc/env.c @@ -40,6 +40,7 @@ #include #include "prototypes.h" #include "defines.h" +#include "shadowlog.h" /* * NEWENVP_STEP must be a power of two. This is the number * of (char *) pointers to allocate at a time, to avoid using @@ -171,7 +172,7 @@ void addenv (const char *string, /*@null@*/const char *value) } newenvp = __newenvp; } else { - (void) fputs (_("Environment overflow\n"), shadow_logfd); + (void) fputs (_("Environment overflow\n"), log_get_logfd()); newenvc--; free (newenvp[newenvc]); } diff --git a/libmisc/find_new_gid.c b/libmisc/find_new_gid.c index 45c68be98..ac2a621a1 100644 --- a/libmisc/find_new_gid.c +++ b/libmisc/find_new_gid.c @@ -38,6 +38,7 @@ #include "prototypes.h" #include "groupio.h" #include "getdef.h" +#include "shadowlog.h" /* * get_ranges - Get the minimum and maximum ID ranges for the search @@ -74,10 +75,10 @@ static int get_ranges (bool sys_group, gid_t *min_id, gid_t *max_id, /* Check that the ranges make sense */ if (*max_id < *min_id) { - (void) fprintf (shadow_logfd, + (void) fprintf (log_get_logfd(), _("%s: Invalid configuration: SYS_GID_MIN (%lu), " "GID_MIN (%lu), SYS_GID_MAX (%lu)\n"), - Prog, (unsigned long) *min_id, + log_get_progname(), (unsigned long) *min_id, getdef_ulong ("GID_MIN", 1000UL), (unsigned long) *max_id); return EINVAL; @@ -97,10 +98,10 @@ static int get_ranges (bool sys_group, gid_t *min_id, gid_t *max_id, /* Check that the ranges make sense */ if (*max_id < *min_id) { - (void) fprintf (shadow_logfd, + (void) fprintf (log_get_logfd(), _("%s: Invalid configuration: GID_MIN (%lu), " "GID_MAX (%lu)\n"), - Prog, (unsigned long) *min_id, + log_get_progname(), (unsigned long) *min_id, (unsigned long) *max_id); return EINVAL; } @@ -213,10 +214,10 @@ int find_new_gid (bool sys_group, * more likely to want to stop and address the * issue. */ - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Encountered error attempting to use " "preferred GID: %s\n"), - Prog, strerror (result)); + log_get_progname(), strerror (result)); return -1; } } @@ -243,9 +244,9 @@ int find_new_gid (bool sys_group, /* Create an array to hold all of the discovered GIDs */ used_gids = malloc (sizeof (bool) * (gid_max +1)); if (NULL == used_gids) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: failed to allocate memory: %s\n"), - Prog, strerror (errno)); + log_get_progname(), strerror (errno)); return -1; } memset (used_gids, false, sizeof (bool) * (gid_max + 1)); @@ -323,10 +324,10 @@ int find_new_gid (bool sys_group, * */ if (!nospam) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Can't get unique system GID (%s). " "Suppressing additional messages.\n"), - Prog, strerror (result)); + log_get_progname(), strerror (result)); SYSLOG ((LOG_ERR, "Error checking available GIDs: %s", strerror (result))); @@ -366,10 +367,10 @@ int find_new_gid (bool sys_group, * */ if (!nospam) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Can't get unique system GID (%s). " "Suppressing additional messages.\n"), - Prog, strerror (result)); + log_get_progname(), strerror (result)); SYSLOG ((LOG_ERR, "Error checking available GIDs: %s", strerror (result))); @@ -426,10 +427,10 @@ int find_new_gid (bool sys_group, * */ if (!nospam) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Can't get unique GID (%s). " "Suppressing additional messages.\n"), - Prog, strerror (result)); + log_get_progname(), strerror (result)); SYSLOG ((LOG_ERR, "Error checking available GIDs: %s", strerror (result))); @@ -469,10 +470,10 @@ int find_new_gid (bool sys_group, * */ if (!nospam) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Can't get unique GID (%s). " "Suppressing additional messages.\n"), - Prog, strerror (result)); + log_get_progname(), strerror (result)); SYSLOG ((LOG_ERR, "Error checking available GIDs: %s", strerror (result))); @@ -488,9 +489,9 @@ int find_new_gid (bool sys_group, } /* The code reached here and found no available IDs in the range */ - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Can't get unique GID (no more available GIDs)\n"), - Prog); + log_get_progname()); SYSLOG ((LOG_WARN, "no more available GIDs on the system")); free (used_gids); return -1; diff --git a/libmisc/find_new_sub_gids.c b/libmisc/find_new_sub_gids.c index 6f418cda4..65f42c0cb 100644 --- a/libmisc/find_new_sub_gids.c +++ b/libmisc/find_new_sub_gids.c @@ -37,6 +37,7 @@ #include "prototypes.h" #include "subordinateio.h" #include "getdef.h" +#include "shadowlog.h" /* * find_new_sub_gids - Find a new unused range of GIDs. @@ -60,18 +61,18 @@ int find_new_sub_gids (gid_t *range_start, unsigned long *range_count) count = getdef_ulong ("SUB_GID_COUNT", 65536); if (min > max || count >= max || (min + count - 1) > max) { - (void) fprintf (shadow_logfd, + (void) fprintf (log_get_logfd(), _("%s: Invalid configuration: SUB_GID_MIN (%lu)," " SUB_GID_MAX (%lu), SUB_GID_COUNT (%lu)\n"), - Prog, min, max, count); + log_get_progname(), min, max, count); return -1; } start = sub_gid_find_free_range(min, max, count); if (start == (gid_t)-1) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Can't get unique subordinate GID range\n"), - Prog); + log_get_progname()); SYSLOG ((LOG_WARN, "no more available subordinate GIDs on the system")); return -1; } diff --git a/libmisc/find_new_sub_uids.c b/libmisc/find_new_sub_uids.c index 346ec893c..d59f9eb6c 100644 --- a/libmisc/find_new_sub_uids.c +++ b/libmisc/find_new_sub_uids.c @@ -37,6 +37,7 @@ #include "prototypes.h" #include "subordinateio.h" #include "getdef.h" +#include "shadowlog.h" /* * find_new_sub_uids - Find a new unused range of UIDs. @@ -60,18 +61,18 @@ int find_new_sub_uids (uid_t *range_start, unsigned long *range_count) count = getdef_ulong ("SUB_UID_COUNT", 65536); if (min > max || count >= max || (min + count - 1) > max) { - (void) fprintf (shadow_logfd, + (void) fprintf (log_get_logfd(), _("%s: Invalid configuration: SUB_UID_MIN (%lu)," " SUB_UID_MAX (%lu), SUB_UID_COUNT (%lu)\n"), - Prog, min, max, count); + log_get_progname(), min, max, count); return -1; } start = sub_uid_find_free_range(min, max, count); if (start == (uid_t)-1) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Can't get unique subordinate UID range\n"), - Prog); + log_get_progname()); SYSLOG ((LOG_WARN, "no more available subordinate UIDs on the system")); return -1; } diff --git a/libmisc/find_new_uid.c b/libmisc/find_new_uid.c index 1d85036c5..7f8b09084 100644 --- a/libmisc/find_new_uid.c +++ b/libmisc/find_new_uid.c @@ -38,6 +38,7 @@ #include "prototypes.h" #include "pwio.h" #include "getdef.h" +#include "shadowlog.h" /* * get_ranges - Get the minimum and maximum ID ranges for the search @@ -74,10 +75,10 @@ static int get_ranges (bool sys_user, uid_t *min_id, uid_t *max_id, /* Check that the ranges make sense */ if (*max_id < *min_id) { - (void) fprintf (shadow_logfd, + (void) fprintf (log_get_logfd(), _("%s: Invalid configuration: SYS_UID_MIN (%lu), " "UID_MIN (%lu), SYS_UID_MAX (%lu)\n"), - Prog, (unsigned long) *min_id, + log_get_progname(), (unsigned long) *min_id, getdef_ulong ("UID_MIN", 1000UL), (unsigned long) *max_id); return EINVAL; @@ -97,10 +98,10 @@ static int get_ranges (bool sys_user, uid_t *min_id, uid_t *max_id, /* Check that the ranges make sense */ if (*max_id < *min_id) { - (void) fprintf (shadow_logfd, + (void) fprintf (log_get_logfd(), _("%s: Invalid configuration: UID_MIN (%lu), " "UID_MAX (%lu)\n"), - Prog, (unsigned long) *min_id, + log_get_progname(), (unsigned long) *min_id, (unsigned long) *max_id); return EINVAL; } @@ -213,10 +214,10 @@ int find_new_uid(bool sys_user, * more likely to want to stop and address the * issue. */ - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Encountered error attempting to use " "preferred UID: %s\n"), - Prog, strerror (result)); + log_get_progname(), strerror (result)); return -1; } } @@ -243,9 +244,9 @@ int find_new_uid(bool sys_user, /* Create an array to hold all of the discovered UIDs */ used_uids = malloc (sizeof (bool) * (uid_max +1)); if (NULL == used_uids) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: failed to allocate memory: %s\n"), - Prog, strerror (errno)); + log_get_progname(), strerror (errno)); return -1; } memset (used_uids, false, sizeof (bool) * (uid_max + 1)); @@ -323,10 +324,10 @@ int find_new_uid(bool sys_user, * */ if (!nospam) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Can't get unique system UID (%s). " "Suppressing additional messages.\n"), - Prog, strerror (result)); + log_get_progname(), strerror (result)); SYSLOG ((LOG_ERR, "Error checking available UIDs: %s", strerror (result))); @@ -366,10 +367,10 @@ int find_new_uid(bool sys_user, * */ if (!nospam) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Can't get unique system UID (%s). " "Suppressing additional messages.\n"), - Prog, strerror (result)); + log_get_progname(), strerror (result)); SYSLOG((LOG_ERR, "Error checking available UIDs: %s", strerror (result))); @@ -426,10 +427,10 @@ int find_new_uid(bool sys_user, * */ if (!nospam) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Can't get unique UID (%s). " "Suppressing additional messages.\n"), - Prog, strerror (result)); + log_get_progname(), strerror (result)); SYSLOG ((LOG_ERR, "Error checking available UIDs: %s", strerror (result))); @@ -469,10 +470,10 @@ int find_new_uid(bool sys_user, * */ if (!nospam) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Can't get unique UID (%s). " "Suppressing additional messages.\n"), - Prog, strerror (result)); + log_get_progname(), strerror (result)); SYSLOG ((LOG_ERR, "Error checking available UIDs: %s", strerror (result))); @@ -488,9 +489,9 @@ int find_new_uid(bool sys_user, } /* The code reached here and found no available IDs in the range */ - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: Can't get unique UID (no more available UIDs)\n"), - Prog); + log_get_progname()); SYSLOG ((LOG_WARN, "no more available UIDs on the system")); free (used_uids); return -1; diff --git a/libmisc/gettime.c b/libmisc/gettime.c index e882300c7..99a69f7ab 100644 --- a/libmisc/gettime.c +++ b/libmisc/gettime.c @@ -36,6 +36,7 @@ #include #include "defines.h" #include "prototypes.h" +#include "shadowlog.h" /* * gettime() returns the time as the number of seconds since the Epoch @@ -50,6 +51,7 @@ char *source_date_epoch; time_t fallback; unsigned long long epoch; + FILE *shadow_logfd = log_get_logfd(); fallback = time (NULL); source_date_epoch = shadow_getenv ("SOURCE_DATE_EPOCH"); diff --git a/libmisc/idmapping.c b/libmisc/idmapping.c index 5c501c812..2af7b49aa 100644 --- a/libmisc/idmapping.c +++ b/libmisc/idmapping.c @@ -40,6 +40,7 @@ #include #include #endif +#include "shadowlog.h" struct map_range *get_map_ranges(int ranges, int argc, char **argv) { @@ -47,28 +48,28 @@ struct map_range *get_map_ranges(int ranges, int argc, char **argv) int idx, argidx; if (ranges < 0 || argc < 0) { - fprintf(shadow_logfd, "%s: error calculating number of arguments\n", Prog); + fprintf(log_get_logfd(), "%s: error calculating number of arguments\n", log_get_progname()); return NULL; } if (ranges != ((argc + 2) / 3)) { - fprintf(shadow_logfd, "%s: ranges: %u is wrong for argc: %d\n", Prog, ranges, argc); + fprintf(log_get_logfd(), "%s: ranges: %u is wrong for argc: %d\n", log_get_progname(), ranges, argc); return NULL; } if ((ranges * 3) > argc) { - fprintf(shadow_logfd, "ranges: %u argc: %d\n", + fprintf(log_get_logfd(), "ranges: %u argc: %d\n", ranges, argc); - fprintf(shadow_logfd, + fprintf(log_get_logfd(), _( "%s: Not enough arguments to form %u mappings\n"), - Prog, ranges); + log_get_progname(), ranges); return NULL; } mappings = calloc(ranges, sizeof(*mappings)); if (!mappings) { - fprintf(shadow_logfd, _( "%s: Memory allocation failure\n"), - Prog); + fprintf(log_get_logfd(), _( "%s: Memory allocation failure\n"), + log_get_progname()); exit(EXIT_FAILURE); } @@ -88,24 +89,24 @@ struct map_range *get_map_ranges(int ranges, int argc, char **argv) return NULL; } if (ULONG_MAX - mapping->upper <= mapping->count || ULONG_MAX - mapping->lower <= mapping->count) { - fprintf(shadow_logfd, _( "%s: subuid overflow detected.\n"), Prog); + fprintf(log_get_logfd(), _( "%s: subuid overflow detected.\n"), log_get_progname()); exit(EXIT_FAILURE); } if (mapping->upper > UINT_MAX || mapping->lower > UINT_MAX || mapping->count > UINT_MAX) { - fprintf(shadow_logfd, _( "%s: subuid overflow detected.\n"), Prog); + fprintf(log_get_logfd(), _( "%s: subuid overflow detected.\n"), log_get_progname()); exit(EXIT_FAILURE); } if (mapping->lower + mapping->count > UINT_MAX || mapping->upper + mapping->count > UINT_MAX) { - fprintf(shadow_logfd, _( "%s: subuid overflow detected.\n"), Prog); + fprintf(log_get_logfd(), _( "%s: subuid overflow detected.\n"), log_get_progname()); exit(EXIT_FAILURE); } if (mapping->lower + mapping->count < mapping->lower || mapping->upper + mapping->count < mapping->upper) { /* this one really shouldn't be possible given previous checks */ - fprintf(shadow_logfd, _( "%s: subuid overflow detected.\n"), Prog); + fprintf(log_get_logfd(), _( "%s: subuid overflow detected.\n"), log_get_progname()); exit(EXIT_FAILURE); } } @@ -176,19 +177,19 @@ void write_mapping(int proc_dir_fd, int ranges, struct map_range *mappings, } else if (strcmp(map_file, "gid_map") == 0) { cap = CAP_SETGID; } else { - fprintf(shadow_logfd, _("%s: Invalid map file %s specified\n"), Prog, map_file); + fprintf(log_get_logfd(), _("%s: Invalid map file %s specified\n"), log_get_progname(), map_file); exit(EXIT_FAILURE); } /* Align setuid- and fscaps-based new{g,u}idmap behavior. */ if (geteuid() == 0 && geteuid() != ruid) { if (prctl(PR_SET_KEEPCAPS, 1, 0, 0, 0) < 0) { - fprintf(shadow_logfd, _("%s: Could not prctl(PR_SET_KEEPCAPS)\n"), Prog); + fprintf(log_get_logfd(), _("%s: Could not prctl(PR_SET_KEEPCAPS)\n"), log_get_progname()); exit(EXIT_FAILURE); } if (seteuid(ruid) < 0) { - fprintf(shadow_logfd, _("%s: Could not seteuid to %d\n"), Prog, ruid); + fprintf(log_get_logfd(), _("%s: Could not seteuid to %d\n"), log_get_progname(), ruid); exit(EXIT_FAILURE); } } @@ -204,7 +205,7 @@ void write_mapping(int proc_dir_fd, int ranges, struct map_range *mappings, data[0].effective |= CAP_TO_MASK(CAP_SETFCAP); data[0].permitted = data[0].effective; if (capset(&hdr, data) < 0) { - fprintf(shadow_logfd, _("%s: Could not set caps\n"), Prog); + fprintf(log_get_logfd(), _("%s: Could not set caps\n"), log_get_progname()); exit(EXIT_FAILURE); } #endif @@ -222,7 +223,7 @@ void write_mapping(int proc_dir_fd, int ranges, struct map_range *mappings, mapping->lower, mapping->count); if ((written <= 0) || (written >= (bufsize - (pos - buf)))) { - fprintf(shadow_logfd, _("%s: snprintf failed!\n"), Prog); + fprintf(log_get_logfd(), _("%s: snprintf failed!\n"), log_get_progname()); exit(EXIT_FAILURE); } pos += written; @@ -231,13 +232,13 @@ void write_mapping(int proc_dir_fd, int ranges, struct map_range *mappings, /* Write the mapping to the mapping file */ fd = openat(proc_dir_fd, map_file, O_WRONLY); if (fd < 0) { - fprintf(shadow_logfd, _("%s: open of %s failed: %s\n"), - Prog, map_file, strerror(errno)); + fprintf(log_get_logfd(), _("%s: open of %s failed: %s\n"), + log_get_progname(), map_file, strerror(errno)); exit(EXIT_FAILURE); } if (write(fd, buf, pos - buf) != (pos - buf)) { - fprintf(shadow_logfd, _("%s: write to %s failed: %s\n"), - Prog, map_file, strerror(errno)); + fprintf(log_get_logfd(), _("%s: write to %s failed: %s\n"), + log_get_progname(), map_file, strerror(errno)); exit(EXIT_FAILURE); } close(fd); diff --git a/libmisc/limits.c b/libmisc/limits.c index 17f9ecd71..e14c99c13 100644 --- a/libmisc/limits.c +++ b/libmisc/limits.c @@ -50,6 +50,7 @@ #include "defines.h" #include #include "getdef.h" +#include "shadowlog.h" #ifdef HAVE_SYS_RESOURCE_H #include #define LIMITS @@ -548,7 +549,7 @@ void setup_limits (const struct passwd *info) #ifdef LIMITS if (info->pw_uid != 0) { if ((setup_user_limits (info->pw_name) & LOGIN_ERROR_LOGIN) != 0) { - (void) fputs (_("Too many logins.\n"), shadow_logfd); + (void) fputs (_("Too many logins.\n"), log_get_logfd()); (void) sleep (2); /* XXX: Should be FAIL_DELAY */ exit (EXIT_FAILURE); } diff --git a/libmisc/pam_pass.c b/libmisc/pam_pass.c index 58a3d3f6e..50d8e3a6e 100644 --- a/libmisc/pam_pass.c +++ b/libmisc/pam_pass.c @@ -46,11 +46,13 @@ #include "defines.h" #include "pam_defs.h" #include "prototypes.h" +#include "shadowlog.h" void do_pam_passwd (const char *user, bool silent, bool change_expired) { pam_handle_t *pamh = NULL; int flags = 0, ret; + FILE *shadow_logfd = log_get_logfd(); if (silent) flags |= PAM_SILENT; diff --git a/libmisc/pam_pass_non_interactive.c b/libmisc/pam_pass_non_interactive.c index 3c95c88cf..ccc3c1e44 100644 --- a/libmisc/pam_pass_non_interactive.c +++ b/libmisc/pam_pass_non_interactive.c @@ -38,6 +38,7 @@ #include #include #include "prototypes.h" +#include "shadowlog.h" /*@null@*/ /*@only@*/static const char *non_interactive_password = NULL; static int ni_conv (int num_msg, @@ -76,9 +77,9 @@ static int ni_conv (int num_msg, switch (msg[count]->msg_style) { case PAM_PROMPT_ECHO_ON: - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: PAM modules requesting echoing are not supported.\n"), - Prog); + log_get_progname()); goto failed_conversation; case PAM_PROMPT_ECHO_OFF: responses[count].resp = strdup (non_interactive_password); @@ -88,7 +89,7 @@ static int ni_conv (int num_msg, break; case PAM_ERROR_MSG: if ( (NULL == msg[count]->msg) - || (fprintf (shadow_logfd, "%s\n", msg[count]->msg) <0)) { + || (fprintf (log_get_logfd(), "%s\n", msg[count]->msg) <0)) { goto failed_conversation; } responses[count].resp = NULL; @@ -101,9 +102,9 @@ static int ni_conv (int num_msg, responses[count].resp = NULL; break; default: - (void) fprintf (shadow_logfd, + (void) fprintf (log_get_logfd(), _("%s: conversation type %d not supported.\n"), - Prog, msg[count]->msg_style); + log_get_progname(), msg[count]->msg_style); goto failed_conversation; } } @@ -143,19 +144,19 @@ int do_pam_passwd_non_interactive (const char *pam_service, ret = pam_start (pam_service, username, &non_interactive_pam_conv, &pamh); if (ret != PAM_SUCCESS) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: (user %s) pam_start failure %d\n"), - Prog, username, ret); + log_get_progname(), username, ret); return 1; } non_interactive_password = password; ret = pam_chauthtok (pamh, 0); if (ret != PAM_SUCCESS) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: (user %s) pam_chauthtok() failed, error:\n" "%s\n"), - Prog, username, pam_strerror (pamh, ret)); + log_get_progname(), username, pam_strerror (pamh, ret)); } (void) pam_end (pamh, PAM_SUCCESS); diff --git a/libmisc/prefix_flag.c b/libmisc/prefix_flag.c index b6628ac49..4c9021d9a 100644 --- a/libmisc/prefix_flag.c +++ b/libmisc/prefix_flag.c @@ -48,6 +48,7 @@ #include "subordinateio.h" #endif /* ENABLE_SUBIDS */ #include "getdef.h" +#include "shadowlog.h" static char *passwd_db_file = NULL; static char *spw_db_file = NULL; @@ -83,18 +84,18 @@ extern const char* process_prefix_flag (const char* short_opt, int argc, char ** && (val = argv[i] + 9)) || (strcmp (argv[i], short_opt) == 0)) { if (NULL != prefix) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: multiple --prefix options\n"), - Prog); + log_get_progname()); exit (E_BAD_ARG); } if (val) { prefix = val; } else if (i + 1 == argc) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: option '%s' requires an argument\n"), - Prog, argv[i]); + log_get_progname(), argv[i]); exit (E_BAD_ARG); } else { prefix = argv[++ i]; @@ -110,9 +111,9 @@ extern const char* process_prefix_flag (const char* short_opt, int argc, char ** /* should we prevent symbolic link from being used as a prefix? */ if ( prefix[0] != '/') { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: prefix must be an absolute path\n"), - Prog); + log_get_progname()); exit (E_BAD_ARG); } size_t len; diff --git a/libmisc/pwdcheck.c b/libmisc/pwdcheck.c index bc6b66f8a..7b66ac7d7 100644 --- a/libmisc/pwdcheck.c +++ b/libmisc/pwdcheck.c @@ -39,6 +39,7 @@ #include "prototypes.h" #include "defines.h" #include "pwauth.h" +#include "shadowlog.h" void passwd_check (const char *user, const char *passwd, unused const char *progname) { @@ -51,7 +52,7 @@ void passwd_check (const char *user, const char *passwd, unused const char *prog if (pw_auth (passwd, user, PW_LOGIN, (char *) 0) != 0) { SYSLOG ((LOG_WARN, "incorrect password for `%s'", user)); (void) sleep (1); - fprintf (shadow_logfd, _("Incorrect password for %s.\n"), user); + fprintf (log_get_logfd(), _("Incorrect password for %s.\n"), user); exit (EXIT_FAILURE); } } diff --git a/libmisc/root_flag.c b/libmisc/root_flag.c index e9a97d440..e48d13447 100644 --- a/libmisc/root_flag.c +++ b/libmisc/root_flag.c @@ -38,6 +38,7 @@ #include "prototypes.h" /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" static void change_root (const char* newroot); @@ -65,18 +66,18 @@ extern void process_root_flag (const char* short_opt, int argc, char **argv) && (val = argv[i] + 7)) || (strcmp (argv[i], short_opt) == 0)) { if (NULL != newroot) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: multiple --root options\n"), - Prog); + log_get_progname()); exit (E_BAD_ARG); } if (val) { newroot = val; } else if (i + 1 == argc) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: option '%s' requires an argument\n"), - Prog, argv[i]); + log_get_progname(), argv[i]); exit (E_BAD_ARG); } else { newroot = argv[++ i]; @@ -94,36 +95,36 @@ static void change_root (const char* newroot) /* Drop privileges */ if ( (setregid (getgid (), getgid ()) != 0) || (setreuid (getuid (), getuid ()) != 0)) { - fprintf (shadow_logfd, _("%s: failed to drop privileges (%s)\n"), - Prog, strerror (errno)); + fprintf (log_get_logfd(), _("%s: failed to drop privileges (%s)\n"), + log_get_progname(), strerror (errno)); exit (EXIT_FAILURE); } if ('/' != newroot[0]) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: invalid chroot path '%s'\n"), - Prog, newroot); + log_get_progname(), newroot); exit (E_BAD_ARG); } if (access (newroot, F_OK) != 0) { - fprintf(shadow_logfd, + fprintf(log_get_logfd(), _("%s: cannot access chroot directory %s: %s\n"), - Prog, newroot, strerror (errno)); + log_get_progname(), newroot, strerror (errno)); exit (E_BAD_ARG); } if (chdir (newroot) != 0) { - fprintf(shadow_logfd, + fprintf(log_get_logfd(), _("%s: cannot chdir to chroot directory %s: %s\n"), - Prog, newroot, strerror (errno)); + log_get_progname(), newroot, strerror (errno)); exit (E_BAD_ARG); } if (chroot (newroot) != 0) { - fprintf(shadow_logfd, + fprintf(log_get_logfd(), _("%s: unable to chroot to directory %s: %s\n"), - Prog, newroot, strerror (errno)); + log_get_progname(), newroot, strerror (errno)); exit (E_BAD_ARG); } } diff --git a/libmisc/salt.c b/libmisc/salt.c index 30eefb9c1..a6a614e0d 100644 --- a/libmisc/salt.c +++ b/libmisc/salt.c @@ -21,6 +21,7 @@ #include "prototypes.h" #include "defines.h" #include "getdef.h" +#include "shadowlog.h" #if (defined CRYPT_GENSALT_IMPLEMENTS_AUTO_ENTROPY && \ CRYPT_GENSALT_IMPLEMENTS_AUTO_ENTROPY) @@ -178,7 +179,7 @@ static long read_random_bytes (void) #endif fail: - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("Unable to obtain random bytes.\n")); exit (1); @@ -506,7 +507,7 @@ static /*@observer@*/const char *gensalt (size_t salt_size) SHA_salt_rounds_to_buf (result, rounds); #endif /* USE_SHA_CRYPT */ } else if (0 != strcmp (method, "DES")) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("Invalid ENCRYPT_METHOD value: '%s'.\n" "Defaulting to DES.\n"), method); @@ -532,7 +533,7 @@ static /*@observer@*/const char *gensalt (size_t salt_size) /* Should not happen, but... */ if (NULL == retval) { - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("Unable to generate a salt from setting " "\"%s\", check your settings in " "ENCRYPT_METHOD and the corresponding " diff --git a/libmisc/setupenv.c b/libmisc/setupenv.c index 74b18723a..d56227ec7 100644 --- a/libmisc/setupenv.c +++ b/libmisc/setupenv.c @@ -47,6 +47,7 @@ #include "defines.h" #include #include "getdef.h" +#include "shadowlog.h" #ifndef USE_PAM static void @@ -219,7 +220,7 @@ void setup_env (struct passwd *info) static char temp_pw_dir[] = "/"; if (!getdef_bool ("DEFAULT_HOME") || chdir ("/") == -1) { - fprintf (shadow_logfd, _("Unable to cd to '%s'\n"), + fprintf (log_get_logfd(), _("Unable to cd to '%s'\n"), info->pw_dir); SYSLOG ((LOG_WARN, "unable to cd to `%s' for user `%s'\n", diff --git a/libmisc/user_busy.c b/libmisc/user_busy.c index 3deebfc33..f63ecc63e 100644 --- a/libmisc/user_busy.c +++ b/libmisc/user_busy.c @@ -45,6 +45,7 @@ #ifdef ENABLE_SUBIDS #include "subordinateio.h" #endif /* ENABLE_SUBIDS */ +#include "shadowlog.h" #ifdef __linux__ static int check_status (const char *name, const char *sname, uid_t uid); @@ -96,9 +97,9 @@ static int user_busy_utmp (const char *name) continue; } - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: user %s is currently logged in\n"), - Prog, name); + log_get_progname(), name); return 1; } @@ -249,9 +250,9 @@ static int user_busy_processes (const char *name, uid_t uid) #ifdef ENABLE_SUBIDS sub_uid_close(); #endif - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: user %s is currently used by process %d\n"), - Prog, name, pid); + log_get_progname(), name, pid); return 1; } @@ -273,9 +274,9 @@ static int user_busy_processes (const char *name, uid_t uid) #ifdef ENABLE_SUBIDS sub_uid_close(); #endif - fprintf (shadow_logfd, + fprintf (log_get_logfd(), _("%s: user %s is currently used by process %d\n"), - Prog, name, pid); + log_get_progname(), name, pid); return 1; } } diff --git a/libmisc/xgetXXbyYY.c b/libmisc/xgetXXbyYY.c index 11f45fc47..5697212db 100644 --- a/libmisc/xgetXXbyYY.c +++ b/libmisc/xgetXXbyYY.c @@ -54,6 +54,7 @@ #include #include #include "prototypes.h" +#include "shadowlog.h" #define XFUNCTION_NAME XPREFIX (FUNCTION_NAME) #define XPREFIX(name) XPREFIX1 (name) @@ -74,7 +75,7 @@ result = malloc(sizeof(LOOKUP_TYPE)); if (NULL == result) { - fprintf (shadow_logfd, _("%s: out of memory\n"), + fprintf (log_get_logfd(), _("%s: out of memory\n"), "x" STRINGIZE(FUNCTION_NAME)); exit (13); } @@ -84,7 +85,7 @@ LOOKUP_TYPE *resbuf = NULL; buffer = (char *)realloc (buffer, length); if (NULL == buffer) { - fprintf (shadow_logfd, _("%s: out of memory\n"), + fprintf (log_get_logfd(), _("%s: out of memory\n"), "x" STRINGIZE(FUNCTION_NAME)); exit (13); } @@ -132,7 +133,7 @@ if (result) { result = DUP_FUNCTION(result); if (NULL == result) { - fprintf (shadow_logfd, _("%s: out of memory\n"), + fprintf (log_get_logfd(), _("%s: out of memory\n"), "x" STRINGIZE(FUNCTION_NAME)); exit (13); } diff --git a/libmisc/xmalloc.c b/libmisc/xmalloc.c index 6d6861452..e8cf7b0ea 100644 --- a/libmisc/xmalloc.c +++ b/libmisc/xmalloc.c @@ -47,6 +47,7 @@ #include #include "defines.h" #include "prototypes.h" +#include "shadowlog.h" /*@maynotreturn@*/ /*@only@*//*@out@*//*@notnull@*/char *xmalloc (size_t size) { @@ -54,9 +55,9 @@ ptr = (char *) malloc (size); if (NULL == ptr) { - (void) fprintf (shadow_logfd, + (void) fprintf (log_get_logfd(), _("%s: failed to allocate memory: %s\n"), - Prog, strerror (errno)); + log_get_progname(), strerror (errno)); exit (13); } return ptr; diff --git a/libsubid/api.c b/libsubid/api.c index 99d7969c1..7a0ebaa5d 100644 --- a/libsubid/api.c +++ b/libsubid/api.c @@ -38,12 +38,13 @@ #include "subordinateio.h" #include "idmapping.h" #include "subid.h" +#include "shadowlog.h" static const char *Prog = "(libsubid)"; -static FILE *shadow_logfd; bool subid_init(const char *progname, FILE * logfd) { + FILE *shadow_logfd; if (progname) { progname = strdup(progname); if (progname) @@ -53,14 +54,15 @@ bool subid_init(const char *progname, FILE * logfd) } if (logfd) { - shadow_logfd = logfd; + log_set_logfd(logfd); return true; } shadow_logfd = fopen("/dev/null", "w"); if (!shadow_logfd) { - shadow_logfd = stderr; + log_set_logfd(stderr); return false; } + log_set_logfd(shadow_logfd); return true; } diff --git a/src/chage.c b/src/chage.c index c74908013..df34da1de 100644 --- a/src/chage.c +++ b/src/chage.c @@ -52,6 +52,7 @@ #include "defines.h" #include "pwio.h" #include "shadowio.h" +#include "shadowlog.h" #ifdef WITH_TCB #include "tcbfuncs.h" #endif @@ -62,7 +63,6 @@ * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static bool dflg = false, /* set last password change date */ @@ -815,7 +815,8 @@ int main (int argc, char **argv) * Get the program name so that error messages can use it. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); sanitize_env (); (void) setlocale (LC_ALL, ""); diff --git a/src/check_subid_range.c b/src/check_subid_range.c index 8a9d5258e..38703b603 100644 --- a/src/check_subid_range.c +++ b/src/check_subid_range.c @@ -16,9 +16,9 @@ #include "prototypes.h" #include "subordinateio.h" #include "idmapping.h" +#include "shadowlog.h" const char *Prog; -FILE *shadow_logfd = NULL; int main(int argc, char **argv) { @@ -26,7 +26,8 @@ int main(int argc, char **argv) unsigned long start, count; bool check_uids; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); if (argc != 5) exit(1); diff --git a/src/chfn.c b/src/chfn.c index 323fd43f5..77c76fad0 100644 --- a/src/chfn.c +++ b/src/chfn.c @@ -52,12 +52,12 @@ #include "pwio.h" /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" /* * Global variables. */ const char *Prog; -FILE *shadow_logfd = NULL; static char fullnm[BUFSIZ]; static char roomno[BUFSIZ]; static char workph[BUFSIZ]; @@ -640,7 +640,8 @@ int main (int argc, char **argv) * prefix to most error messages. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); sanitize_env (); (void) setlocale (LC_ALL, ""); diff --git a/src/chgpasswd.c b/src/chgpasswd.c index 25dfc2461..fe68d58cf 100644 --- a/src/chgpasswd.c +++ b/src/chgpasswd.c @@ -54,12 +54,12 @@ #endif /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static bool eflg = false; static bool md5flg = false; #if defined(USE_SHA_CRYPT) || defined(USE_BCRYPT) || defined(USE_YESCRYPT) @@ -438,7 +438,8 @@ int main (int argc, char **argv) int line = 0; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/chpasswd.c b/src/chpasswd.c index d55a47ddb..efbfa045b 100644 --- a/src/chpasswd.c +++ b/src/chpasswd.c @@ -51,12 +51,12 @@ #include "shadowio.h" /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static bool eflg = false; static bool md5flg = false; #if defined(USE_SHA_CRYPT) || defined(USE_BCRYPT) || defined(USE_YESCRYPT) @@ -430,7 +430,8 @@ int main (int argc, char **argv) int line = 0; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/chsh.c b/src/chsh.c index 1cafb8b62..92b5e5d9a 100644 --- a/src/chsh.c +++ b/src/chsh.c @@ -51,6 +51,7 @@ #endif /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" #ifndef SHELLS_FILE #define SHELLS_FILE "/etc/shells" @@ -59,7 +60,6 @@ * Global variables */ const char *Prog; /* Program name */ -FILE *shadow_logfd = NULL; static bool amroot; /* Real UID is root */ static char loginsh[BUFSIZ]; /* Name of new login shell */ /* command line options */ @@ -442,7 +442,8 @@ int main (int argc, char **argv) * most error messages. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/expiry.c b/src/expiry.c index 79db32ff4..31604a6da 100644 --- a/src/expiry.c +++ b/src/expiry.c @@ -43,10 +43,10 @@ #include "prototypes.h" /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" /* Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static bool cflg = false; /* local function prototypes */ @@ -145,7 +145,8 @@ int main (int argc, char **argv) struct spwd *spwd; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); sanitize_env (); diff --git a/src/faillog.c b/src/faillog.c index d09f15113..db4fc72b7 100644 --- a/src/faillog.c +++ b/src/faillog.c @@ -46,6 +46,7 @@ #include "prototypes.h" /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" /* local function prototypes */ static /*@noreturn@*/void usage (int status); @@ -62,7 +63,6 @@ static void reset (void); * Global variables */ const char *Prog; /* Program name */ -FILE *shadow_logfd = NULL; static FILE *fail; /* failure file stream */ static time_t seconds; /* that number of days in seconds */ static unsigned long umin; /* if uflg and has_umin, only display users with uid >= umin */ @@ -574,7 +574,8 @@ int main (int argc, char **argv) * most error messages. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/free_subid_range.c b/src/free_subid_range.c index 97fff6ad7..c08d5fcc7 100644 --- a/src/free_subid_range.c +++ b/src/free_subid_range.c @@ -3,11 +3,11 @@ #include "subid.h" #include "stdlib.h" #include "prototypes.h" +#include "shadowlog.h" /* Test program for the subid freeing routine */ const char *Prog; -FILE *shadow_logfd = NULL; void usage(void) { @@ -24,7 +24,8 @@ int main(int argc, char *argv[]) bool group = false; // get subuids by default Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); while ((c = getopt(argc, argv, "g")) != EOF) { switch(c) { case 'g': group = true; break; diff --git a/src/get_subid_owners.c b/src/get_subid_owners.c index 338a5a8bc..14a89ca07 100644 --- a/src/get_subid_owners.c +++ b/src/get_subid_owners.c @@ -2,9 +2,9 @@ #include "subid.h" #include "stdlib.h" #include "prototypes.h" +#include "shadowlog.h" const char *Prog; -FILE *shadow_logfd = NULL; void usage(void) { @@ -20,7 +20,8 @@ int main(int argc, char *argv[]) uid_t *uids; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); if (argc < 2) { usage(); } diff --git a/src/getsubids.c b/src/getsubids.c index f652cb638..2bda1473c 100644 --- a/src/getsubids.c +++ b/src/getsubids.c @@ -3,9 +3,9 @@ #include #include "subid.h" #include "prototypes.h" +#include "shadowlog.h" const char *Prog; -FILE *shadow_logfd = NULL; void usage(void) { @@ -22,7 +22,8 @@ int main(int argc, char *argv[]) const char *owner; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); if (argc < 2) usage(); owner = argv[1]; diff --git a/src/gpasswd.c b/src/gpasswd.c index 04bed83d6..8bbbe6bef 100644 --- a/src/gpasswd.c +++ b/src/gpasswd.c @@ -53,12 +53,12 @@ /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" /* * Global variables */ /* The name of this command, as it is invoked */ const char *Prog; -FILE *shadow_logfd = NULL; #ifdef SHADOWGRP /* Indicate if shadow groups are enabled on the system @@ -989,7 +989,8 @@ int main (int argc, char **argv) */ bywho = getuid (); Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); OPENLOG ("gpasswd"); setbuf (stdout, NULL); diff --git a/src/groupadd.c b/src/groupadd.c index d7f68b1a1..533761c80 100644 --- a/src/groupadd.c +++ b/src/groupadd.c @@ -56,6 +56,7 @@ #ifdef SHADOWGRP #include "sgroupio.h" #endif +#include "shadowlog.h" /* * exit status values @@ -72,7 +73,6 @@ * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static /*@null@*/char *group_name; static gid_t group_id; @@ -599,7 +599,8 @@ int main (int argc, char **argv) * Get my name so that I can use it to report errors. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/groupdel.c b/src/groupdel.c index 364cac8de..a4774e463 100644 --- a/src/groupdel.c +++ b/src/groupdel.c @@ -54,11 +54,11 @@ #ifdef SHADOWGRP #include "sgroupio.h" #endif +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static char *group_name; static gid_t group_id = -1; @@ -377,7 +377,8 @@ int main (int argc, char **argv) * Get my name so that I can use it to report errors. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/groupmems.c b/src/groupmems.c index c2b255836..69f8a77d5 100644 --- a/src/groupmems.c +++ b/src/groupmems.c @@ -47,6 +47,7 @@ #ifdef SHADOWGRP #include "sgroupio.h" #endif +#include "shadowlog.h" /* Exit Status Values */ /*@-exitarg@*/ @@ -65,7 +66,6 @@ * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static char *adduser = NULL; static char *deluser = NULL; @@ -596,7 +596,8 @@ int main (int argc, char **argv) * Get my name so that I can use it to report errors. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/groupmod.c b/src/groupmod.c index acd6f350a..6d1a24793 100644 --- a/src/groupmod.c +++ b/src/groupmod.c @@ -56,6 +56,7 @@ #ifdef SHADOWGRP #include "sgroupio.h" #endif +#include "shadowlog.h" /* * exit status values */ @@ -76,7 +77,6 @@ * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; #ifdef SHADOWGRP static bool is_shadow_grp; @@ -793,7 +793,8 @@ int main (int argc, char **argv) * Get my name so that I can use it to report errors. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/groups.c b/src/groups.c index 3bfd48300..70e3fcb23 100644 --- a/src/groups.c +++ b/src/groups.c @@ -39,11 +39,11 @@ #include #include "defines.h" #include "prototypes.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; /* local function prototypes */ static void print_groups (const char *member); @@ -127,7 +127,8 @@ int main (int argc, char **argv) * Get the program name so that error messages can use it. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); if (argc == 1) { diff --git a/src/grpck.c b/src/grpck.c index 69bef0368..c4387b7a2 100644 --- a/src/grpck.c +++ b/src/grpck.c @@ -45,6 +45,7 @@ #include "nscd.h" #include "sssd.h" #include "prototypes.h" +#include "shadowlog.h" #ifdef SHADOWGRP #include "sgroupio.h" @@ -66,7 +67,6 @@ * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static const char *grp_file = GROUP_FILE; static bool use_system_grp_file = true; @@ -841,7 +841,8 @@ int main (int argc, char **argv) * Get my name so that I can use it to report errors. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/grpconv.c b/src/grpconv.c index aecafa404..d3d0fb967 100644 --- a/src/grpconv.c +++ b/src/grpconv.c @@ -55,11 +55,11 @@ #ifdef SHADOWGRP #include "groupio.h" #include "sgroupio.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static bool gr_locked = false; static bool sgr_locked = false; @@ -147,7 +147,8 @@ int main (int argc, char **argv) struct sgrp sgent; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/grpunconv.c b/src/grpunconv.c index d750e2bd6..b3a34ab88 100644 --- a/src/grpunconv.c +++ b/src/grpunconv.c @@ -55,11 +55,11 @@ #ifdef SHADOWGRP #include "groupio.h" #include "sgroupio.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static bool gr_locked = false; static bool sgr_locked = false; @@ -146,7 +146,8 @@ int main (int argc, char **argv) const struct sgrp *sg; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/lastlog.c b/src/lastlog.c index 1b1803e18..b3a152d97 100644 --- a/src/lastlog.c +++ b/src/lastlog.c @@ -50,6 +50,7 @@ #include "getdef.h" /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" /* * Needed for MkLinux DR1/2/2.1 - J. @@ -62,7 +63,6 @@ * Global variables */ const char *Prog; /* Program name */ -FILE *shadow_logfd = NULL; static FILE *lastlogfile; /* lastlog file stream */ static unsigned long umin; /* if uflg and has_umin, only display users with uid >= umin */ static bool has_umin = false; @@ -318,7 +318,8 @@ int main (int argc, char **argv) * most error messages. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/login.c b/src/login.c index 79517f8a0..1623f29d4 100644 --- a/src/login.c +++ b/src/login.c @@ -53,6 +53,7 @@ #include "pwauth.h" /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" #ifdef USE_PAM #include "pam_defs.h" @@ -83,7 +84,6 @@ static pam_handle_t *pamh = NULL; * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static const char *hostname = ""; static /*@null@*/ /*@only@*/char *username = NULL; @@ -578,7 +578,8 @@ int main (int argc, char **argv) amroot = (getuid () == 0); Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); if (geteuid() != 0) { fprintf (stderr, _("%s: Cannot possibly work without effective root\n"), Prog); diff --git a/src/logoutd.c b/src/logoutd.c index 02935a913..1f96a68e5 100644 --- a/src/logoutd.c +++ b/src/logoutd.c @@ -40,11 +40,11 @@ #include #include "defines.h" #include "prototypes.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; #ifndef DEFAULT_HUP_MESG #define DEFAULT_HUP_MESG _("login time exceeded\n\n") @@ -188,7 +188,8 @@ int main (int argc, char **argv) * Start syslogging everything */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); OPENLOG ("logoutd"); diff --git a/src/new_subid_range.c b/src/new_subid_range.c index 96e642327..8975b7250 100644 --- a/src/new_subid_range.c +++ b/src/new_subid_range.c @@ -3,11 +3,11 @@ #include "subid.h" #include "stdlib.h" #include "prototypes.h" +#include "shadowlog.h" /* Test program for the subid creation routine */ const char *Prog; -FILE *shadow_logfd = NULL; void usage(void) { @@ -27,7 +27,8 @@ int main(int argc, char *argv[]) bool ok; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); while ((c = getopt(argc, argv, "gn")) != EOF) { switch(c) { case 'n': makenew = true; break; diff --git a/src/newgidmap.c b/src/newgidmap.c index 51a2eb440..87581c433 100644 --- a/src/newgidmap.c +++ b/src/newgidmap.c @@ -41,12 +41,12 @@ #include "subordinateio.h" #include "getdef.h" #include "idmapping.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static bool verify_range(struct passwd *pw, struct map_range *range, bool *allow_setgroups) @@ -177,7 +177,8 @@ int main(int argc, char **argv) bool allow_setgroups = false; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); /* * The valid syntax are diff --git a/src/newgrp.c b/src/newgrp.c index 566f1c899..d76bc90ad 100644 --- a/src/newgrp.c +++ b/src/newgrp.c @@ -44,12 +44,12 @@ #include "prototypes.h" /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; extern char **newenvp; extern char **environ; @@ -445,7 +445,8 @@ int main (int argc, char **argv) * don't need to re-exec anything. -- JWP */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); is_newgrp = (strcmp (Prog, "newgrp") == 0); OPENLOG (is_newgrp ? "newgrp" : "sg"); argc--; diff --git a/src/newuidmap.c b/src/newuidmap.c index c9a92155c..d33e3e7e6 100644 --- a/src/newuidmap.c +++ b/src/newuidmap.c @@ -41,12 +41,12 @@ #include "subordinateio.h" #include "getdef.h" #include "idmapping.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static bool verify_range(struct passwd *pw, struct map_range *range) { @@ -107,7 +107,8 @@ int main(int argc, char **argv) int written; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); /* * The valid syntax are diff --git a/src/newusers.c b/src/newusers.c index edbb40108..db8dc95a0 100644 --- a/src/newusers.c +++ b/src/newusers.c @@ -70,12 +70,12 @@ #include "subordinateio.h" #endif /* ENABLE_SUBIDS */ #include "chkname.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static bool rflg = false; /* create a system account */ #ifndef USE_PAM @@ -1071,7 +1071,8 @@ int main (int argc, char **argv) #endif /* USE_PAM */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/passwd.c b/src/passwd.c index 8ec551255..be217d31a 100644 --- a/src/passwd.c +++ b/src/passwd.c @@ -50,6 +50,7 @@ #include "pwauth.h" #include "pwio.h" #include "shadowio.h" +#include "shadowlog.h" /* * exit status values @@ -66,7 +67,6 @@ * Global variables */ const char *Prog; /* Program name */ -FILE *shadow_logfd = NULL; static char *name; /* The name of user whose password is being changed */ static char *myname; /* The current user's name */ @@ -761,7 +761,8 @@ int main (int argc, char **argv) * most error messages. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/pwck.c b/src/pwck.c index 4ce86af29..d79586bc4 100644 --- a/src/pwck.c +++ b/src/pwck.c @@ -52,6 +52,7 @@ #ifdef WITH_TCB #include "tcbfuncs.h" #endif /* WITH_TCB */ +#include "shadowlog.h" /* * Exit codes @@ -70,7 +71,6 @@ * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static bool use_system_pw_file = true; static bool use_system_spw_file = true; @@ -857,7 +857,8 @@ int main (int argc, char **argv) * Get my name so that I can use it to report errors. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/pwconv.c b/src/pwconv.c index 85ad9699e..af6107fd9 100644 --- a/src/pwconv.c +++ b/src/pwconv.c @@ -73,6 +73,7 @@ #include "shadowio.h" #include "nscd.h" #include "sssd.h" +#include "shadowlog.h" /* * exit status values @@ -89,7 +90,6 @@ * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static bool spw_locked = false; static bool pw_locked = false; @@ -177,7 +177,8 @@ int main (int argc, char **argv) struct spwd spent; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/pwunconv.c b/src/pwunconv.c index a5ee999ef..c228befdf 100644 --- a/src/pwunconv.c +++ b/src/pwunconv.c @@ -48,12 +48,12 @@ #include "shadowio.h" /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static bool spw_locked = false; static bool pw_locked = false; @@ -138,7 +138,8 @@ int main (int argc, char **argv) const struct spwd *spwd; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/su.c b/src/su.c index 58882caf0..e7e3e967a 100644 --- a/src/su.c +++ b/src/su.c @@ -77,12 +77,12 @@ #endif /* USE_PAM */ /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static /*@observer@*/const char *caller_tty = NULL; /* Name of tty SU is run from */ static bool caller_is_root = false; static uid_t caller_uid; @@ -734,7 +734,8 @@ static void save_caller_context (char **argv) * most error messages. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); caller_uid = getuid (); caller_is_root = (caller_uid == 0); diff --git a/src/sulogin.c b/src/sulogin.c index a5a150c1a..e438e3cbe 100644 --- a/src/sulogin.c +++ b/src/sulogin.c @@ -45,12 +45,12 @@ #include "pwauth.h" /*@-exitarg@*/ #include "exitcodes.h" +#include "shadowlog.h" /* * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static char name[BUFSIZ]; static char pass[BUFSIZ]; @@ -107,7 +107,8 @@ static RETSIGTYPE catch_signals (unused int sig) #endif Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); (void) textdomain (PACKAGE); diff --git a/src/useradd.c b/src/useradd.c index 3eec17787..179e08984 100644 --- a/src/useradd.c +++ b/src/useradd.c @@ -78,6 +78,7 @@ #ifdef WITH_TCB #include "tcbfuncs.h" #endif +#include "shadowlog.h" #ifndef SKEL_DIR #define SKEL_DIR "/etc/skel" @@ -96,7 +97,6 @@ * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; /* * These defaults are used if there is no defaults file. @@ -2459,7 +2459,8 @@ int main (int argc, char **argv) * Get my name so that I can use it to report errors. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/userdel.c b/src/userdel.c index 459b00218..ef6354375 100644 --- a/src/userdel.c +++ b/src/userdel.c @@ -72,6 +72,7 @@ #ifdef ENABLE_SUBIDS #include "subordinateio.h" #endif /* ENABLE_SUBIDS */ +#include "shadowlog.h" /* * exit status values @@ -91,7 +92,6 @@ * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static char *user_name; static uid_t user_id; @@ -1016,7 +1016,8 @@ int main (int argc, char **argv) * Get my name so that I can use it to report errors. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); (void) textdomain (PACKAGE); diff --git a/src/usermod.c b/src/usermod.c index 0a075565f..10f9ccfd3 100644 --- a/src/usermod.c +++ b/src/usermod.c @@ -74,6 +74,7 @@ #ifdef WITH_TCB #include "tcbfuncs.h" #endif +#include "shadowlog.h" /* * exit status values @@ -105,7 +106,6 @@ * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static char *user_name; static char *user_newname; @@ -2181,7 +2181,8 @@ int main (int argc, char **argv) * Get my name so that I can use it to report errors. */ Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR); diff --git a/src/vipw.c b/src/vipw.c index 1a69ef285..9c94d6bbd 100644 --- a/src/vipw.c +++ b/src/vipw.c @@ -53,6 +53,7 @@ #include #include "tcbfuncs.h" #endif /* WITH_TCB */ +#include "shadowlog.h" #define MSG_WARN_EDIT_OTHER_FILE _( \ "You have modified %s.\n"\ @@ -63,7 +64,6 @@ * Global variables */ const char *Prog; -FILE *shadow_logfd = NULL; static const char *filename, *fileeditname; static bool filelocked = false; @@ -485,7 +485,8 @@ int main (int argc, char **argv) bool do_vipw; Prog = Basename (argv[0]); - shadow_logfd = stderr; + log_set_progname(Prog); + log_set_logfd(stderr); (void) setlocale (LC_ALL, ""); (void) bindtextdomain (PACKAGE, LOCALEDIR);