change getpwuid on getpwuid_r
remove exit() edit chdir in chold process
This commit is contained in:
parent
c831300a14
commit
be7c5eb7ca
1 changed files with 39 additions and 14 deletions
|
|
@ -809,7 +809,10 @@ cli_start_program(clixon_handle h,
|
|||
int retval = -1;
|
||||
char *script_path = NULL;
|
||||
char *runner = NULL;
|
||||
struct passwd *pw = NULL;
|
||||
char *buf = NULL;
|
||||
struct passwd pw, *pwresult = NULL;
|
||||
size_t bufsize;
|
||||
int s;
|
||||
|
||||
/* Check parameters */
|
||||
if (cvec_len(argv) == 0){
|
||||
|
|
@ -837,28 +840,50 @@ cli_start_program(clixon_handle h,
|
|||
script_path = cv_string_get(cvec_i(cvv, 1));
|
||||
}
|
||||
|
||||
if ((pw = getpwuid(getuid())) == NULL){
|
||||
clixon_err(OE_PLUGIN, errno, "getpwuid");
|
||||
bufsize = sysconf(_SC_GETPW_R_SIZE_MAX);
|
||||
if (bufsize == -1){
|
||||
bufsize = 16384;
|
||||
}
|
||||
buf = malloc(bufsize);
|
||||
if (buf == NULL) {
|
||||
perror("malloc");
|
||||
goto done;
|
||||
}
|
||||
if (chdir(pw->pw_dir) < 0){
|
||||
clixon_err(OE_PLUGIN, errno, "chdir");
|
||||
|
||||
s = getpwuid_r(getuid(), &pw, buf, bufsize, &pwresult);
|
||||
if (pwresult == NULL) {
|
||||
if (s == 0)
|
||||
clixon_err(OE_PLUGIN, errno, "getpwuid_r");
|
||||
else
|
||||
perror("getpwuid_r");
|
||||
goto done;
|
||||
}
|
||||
|
||||
/* main run */
|
||||
if ((pid = fork()) == 0) {
|
||||
/* child process */
|
||||
if (chdir(pw.pw_dir) < 0){
|
||||
clixon_err(OE_PLUGIN, errno, "chdir");
|
||||
}
|
||||
execlp(runner, runner, script_path, NULL);
|
||||
clixon_err(OE_PLUGIN, errno, "Error run script");
|
||||
exit(0);
|
||||
return -1;
|
||||
}else if(pid == -1){
|
||||
clixon_err(OE_PLUGIN, errno, "fork");
|
||||
}else{
|
||||
/* parent process */
|
||||
int status;
|
||||
if (waitpid(pid, &status, 0) != pid ){
|
||||
clixon_err(OE_PLUGIN, errno, "waitpid error");
|
||||
goto done;
|
||||
} else {
|
||||
return WEXITSTATUS(status);
|
||||
}
|
||||
|
||||
if (waitpid(pid, &retval, 0) == pid)
|
||||
goto done;
|
||||
else
|
||||
goto done;
|
||||
|
||||
}
|
||||
retval = 0;
|
||||
done:
|
||||
if(buf)
|
||||
free(buf);
|
||||
return retval;
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue