This avoids using argv[0], which is controlled by the user,
and might inject arbitrary text in stderr and the logs.
Link: <https://github.com/shadow-maint/shadow/issues/959>
Link: <https://github.com/shadow-maint/shadow/pull/960>
Cc: "Skyler Ferrante (RIT Student)" <sjf5462@rit.edu>
Cc: "Serge E. Hallyn" <serge@hallyn.com>
Cc: Karel Zak <kzak@redhat.com>
Cc: Iker Pedrosa <ipedrosa@redhat.com>
Cc: Christian Brauner <christian@brauner.io>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
/*
* Global variables
*/
-const char *Prog;
+static const char *Prog;
static const char *filename, *fileeditname;
static bool filelocked = false;
bool editshadow = false;
bool do_vigr;
- Prog = Basename (argv[0]);
+ do_vigr = (strcmp(Basename(argv[0]), "vigr") == 0);
+
+ Prog = do_vigr ? "vigr" : "vipw";
log_set_progname(Prog);
log_set_logfd(stderr);
process_root_flag ("-R", argc, argv);
- do_vigr = (strcmp(Prog, "vigr") == 0);
-
- OPENLOG(do_vigr ? "vigr" : "vipw");
+ OPENLOG(Prog);
{
/*