X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fexec.c;h=246584b71436b907da46e40d0de803e8a63950a6;hb=45492ba3d0119874e2f2878d68089fc8f62268a4;hp=c84c1c7b63463440dd99aa71dd78f26c9c8a2b1a;hpb=79963d13c1884d1d92667cc502ad20758b084a12;p=collectd.git diff --git a/src/exec.c b/src/exec.c index c84c1c7b..246584b7 100644 --- a/src/exec.c +++ b/src/exec.c @@ -250,7 +250,7 @@ static void set_environment(void) /* {{{ */ CDTIME_T_TO_DOUBLE(plugin_get_interval())); setenv("COLLECTD_INTERVAL", buffer, /* overwrite = */ 1); - ssnprintf(buffer, sizeof(buffer), "%s", hostname_g); + sstrncpy(buffer, hostname_g, sizeof(buffer)); setenv("COLLECTD_HOSTNAME", buffer, /* overwrite = */ 1); #else ssnprintf(buffer, sizeof(buffer), "COLLECTD_INTERVAL=%.3f", @@ -369,11 +369,17 @@ static int fork_child(program_list_t *pl, int *fd_in, int *fd_out, struct passwd *sp_ptr; struct passwd sp; - char nambuf[2048]; if (pl->pid != 0) return (-1); + long int nambuf_size = sysconf(_SC_GETPW_R_SIZE_MAX); + if (nambuf_size <= 0) + nambuf_size = sysconf(_SC_PAGESIZE); + if (nambuf_size <= 0) + nambuf_size = 4096; + char nambuf[nambuf_size]; + if ((create_pipe(fd_pipe_in) == -1) || (create_pipe(fd_pipe_out) == -1) || (create_pipe(fd_pipe_err) == -1)) goto failed; @@ -382,7 +388,7 @@ static int fork_child(program_list_t *pl, int *fd_in, int *fd_out, status = getpwnam_r(pl->user, &sp, nambuf, sizeof(nambuf), &sp_ptr); if (status != 0) { ERROR("exec plugin: Failed to get user information for user ``%s'': %s", - pl->user, sstrerror(errno, errbuf, sizeof(errbuf))); + pl->user, sstrerror(status, errbuf, sizeof(errbuf))); goto failed; } @@ -406,11 +412,18 @@ static int fork_child(program_list_t *pl, int *fd_in, int *fd_out, struct group *gr_ptr = NULL; struct group gr; - status = getgrnam_r(pl->group, &gr, nambuf, sizeof(nambuf), &gr_ptr); + long int grbuf_size = sysconf(_SC_GETGR_R_SIZE_MAX); + if (grbuf_size <= 0) + grbuf_size = sysconf(_SC_PAGESIZE); + if (grbuf_size <= 0) + grbuf_size = 4096; + char grbuf[grbuf_size]; + + status = getgrnam_r(pl->group, &gr, grbuf, sizeof(grbuf), &gr_ptr); if (0 != status) { ERROR("exec plugin: Failed to get group information " "for group ``%s'': %s", - pl->group, sstrerror(errno, errbuf, sizeof(errbuf))); + pl->group, sstrerror(status, errbuf, sizeof(errbuf))); goto failed; } if (NULL == gr_ptr) { @@ -500,7 +513,7 @@ failed: static int parse_line(char *buffer) /* {{{ */ { if (strncasecmp("PUTVAL", buffer, strlen("PUTVAL")) == 0) - return (handle_putval(stdout, buffer)); + return (cmd_handle_putval(stdout, buffer)); else if (strncasecmp("PUTNOTIF", buffer, strlen("PUTNOTIF")) == 0) return (handle_putnotif(stdout, buffer)); else { @@ -787,7 +800,7 @@ static int exec_read(void) /* {{{ */ pthread_attr_init(&attr); pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED); - plugin_thread_create(&t, &attr, exec_read_one, (void *)pl); + plugin_thread_create(&t, &attr, exec_read_one, (void *)pl, "exec read"); pthread_attr_destroy(&attr); } /* for (pl) */ @@ -826,7 +839,8 @@ static int exec_notification(const notification_t *n, /* {{{ */ pthread_attr_init(&attr); pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED); - plugin_thread_create(&t, &attr, exec_notification_one, (void *)pln); + plugin_thread_create(&t, &attr, exec_notification_one, (void *)pln, + "exec notify"); pthread_attr_destroy(&attr); } /* for (pl) */