mirror of
https://github.com/shadow-maint/shadow.git
synced 2024-11-24 10:35:01 +08:00
3b89b71680
CWE-457 by CodeQL. Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
105 lines
1.9 KiB
C
105 lines
1.9 KiB
C
#include <dirent.h>
|
|
#include <errno.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <sys/stat.h>
|
|
#include <sys/types.h>
|
|
#include <sys/wait.h>
|
|
#include <unistd.h>
|
|
#include <lib/prototypes.h>
|
|
#include "run_part.h"
|
|
#include "shadowlog_internal.h"
|
|
|
|
int run_part (char *script_path, const char *name, const char *action)
|
|
{
|
|
int pid;
|
|
int wait_status;
|
|
int pid_status;
|
|
char *args[] = { script_path, NULL };
|
|
|
|
pid=fork();
|
|
if (pid==-1) {
|
|
perror ("Could not fork");
|
|
return 1;
|
|
}
|
|
if (pid==0) {
|
|
setenv ("ACTION",action,1);
|
|
setenv ("SUBJECT",name,1);
|
|
execv (script_path,args);
|
|
perror ("execv");
|
|
exit(1);
|
|
}
|
|
|
|
pid_status = wait (&wait_status);
|
|
if (pid_status == pid) {
|
|
return (wait_status);
|
|
}
|
|
|
|
perror ("waitpid");
|
|
return (1);
|
|
}
|
|
|
|
int run_parts (const char *directory, const char *name, const char *action)
|
|
{
|
|
struct dirent **namelist;
|
|
int scanlist;
|
|
int n;
|
|
int execute_result = 0;
|
|
|
|
scanlist = scandir (directory, &namelist, 0, alphasort);
|
|
if (scanlist<=0) {
|
|
return (0);
|
|
}
|
|
|
|
for (n=0; n<scanlist; n++) {
|
|
int path_length;
|
|
struct stat sb;
|
|
|
|
path_length=strlen(directory) + strlen(namelist[n]->d_name) + 2;
|
|
char *s = (char*)malloc(path_length);
|
|
if (!s) {
|
|
printf ("could not allocate memory\n");
|
|
for (; n<scanlist; n++) {
|
|
free (namelist[n]);
|
|
}
|
|
free (namelist);
|
|
return (1);
|
|
}
|
|
snprintf (s, path_length, "%s/%s", directory, namelist[n]->d_name);
|
|
|
|
execute_result = 0;
|
|
if (stat (s, &sb) == -1) {
|
|
perror ("stat");
|
|
free (s);
|
|
for (; n<scanlist; n++) {
|
|
free (namelist[n]);
|
|
}
|
|
free (namelist);
|
|
return (1);
|
|
}
|
|
|
|
if (S_ISREG (sb.st_mode) || S_ISLNK (sb.st_mode)) {
|
|
execute_result = run_part (s, name, action);
|
|
}
|
|
|
|
free (s);
|
|
|
|
if (execute_result!=0) {
|
|
fprintf (shadow_logfd,
|
|
"%s: did not exit cleanly.\n",
|
|
namelist[n]->d_name);
|
|
for (; n<scanlist; n++) {
|
|
free (namelist[n]);
|
|
}
|
|
break;
|
|
}
|
|
|
|
free (namelist[n]);
|
|
}
|
|
free (namelist);
|
|
|
|
return (execute_result);
|
|
}
|
|
|