* Close the listening Unix socket of the mod_cgid daemon in the CGI scripts.

PR: 47335
Submitted by: Kornél Pál <kornelpal gmail.com>
Reviewed by: rpluem


git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@783740 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Ruediger Pluem
2009-06-11 12:32:59 +00:00
parent d0f13e518c
commit c250b42a48
2 changed files with 14 additions and 8 deletions

View File

@ -6,8 +6,11 @@ Changes with Apache 2.3.3
mod_proxy_ajp: Avoid delivering content from a previous request which
failed to send a request body. PR 46949 [Ruediger Pluem]
*) mod_cgid: Do not leak the listening Unix socket file descriptor to the
CGI process. PR 47335 [Kornél Pál <kornelpal gmail.com>]
*) mod_rewrite: Remove locking for writing to the rewritelog.
PR 46942 [Dan Poirier <poirier pobox.com>]
PR 46942 [Dan Poirier <poirier pobox.com>]
*) mod_alias: check sanity in Redirect arguments.
PR 44729 [Sönke Tesch <st kino-fahrplan.de>, Jim Jagielski]

View File

@ -302,6 +302,13 @@ static void cgid_maint(int reason, void *data, apr_wait_t status)
}
#endif
static apr_status_t close_unix_socket(void *thefd)
{
int fd = (int)((long)thefd);
return close(fd);
}
/* deal with incomplete reads and signals
* assume you really have to read buf_size bytes
*/
@ -653,6 +660,9 @@ static int cgid_server(void *data)
}
}
apr_pool_cleanup_register(pcgi, (void *)((long)sd),
close_unix_socket, close_unix_socket);
/* if running as root, switch to configured user/group */
if ((rc = ap_run_drop_privileges(pcgi, ap_server_conf)) != 0) {
return rc;
@ -1152,13 +1162,6 @@ static int log_script(request_rec *r, cgid_server_conf * conf, int ret,
return ret;
}
static apr_status_t close_unix_socket(void *thefd)
{
int fd = (int)((long)thefd);
return close(fd);
}
static int connect_to_daemon(int *sdptr, request_rec *r,
cgid_server_conf *conf)
{