summaryrefslogtreecommitdiffstats
path: root/modules
diff options
context:
space:
mode:
authorJoe Orton <jorton@apache.org>2021-02-25 10:11:57 +0100
committerJoe Orton <jorton@apache.org>2021-02-25 10:11:57 +0100
commitce017390110ce49ca9eccba8b2eabfc2870b7932 (patch)
treef0c689850af061a4ffad8a945a903ac225b551c9 /modules
parent *) core: Adding SSL related inquiry functions to the server API. (diff)
downloadapache2-ce017390110ce49ca9eccba8b2eabfc2870b7932.tar.xz
apache2-ce017390110ce49ca9eccba8b2eabfc2870b7932.zip
Enable mod_cgid stderr handling via Unix socket fd transfer by
default, rather than as an opt-in configure flag. (This has been tested in Fedora for >12 months without seeing any new problems) * configure.in: Check for CMSG_DATA here, and define HAVE_FDPASSING and $ap_has_fdpassing if fd passing is supported. * modules/generator/config5.m4, modules/generator/mod_cgid.c: Drop configure flag for mod_cgid fdpassing support, instead enable where possible by default. * modules/proxy/config.m4: Rely on configure test for CMSG_DATA. * .travis.yml: Switch test for cgid fdpassing for testing w/o CMSG_DATA. Github: closes #172 PR: 54221 git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1886912 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'modules')
-rw-r--r--modules/generators/config5.m411
-rw-r--r--modules/generators/mod_cgid.c10
-rw-r--r--modules/proxy/config.m47
3 files changed, 6 insertions, 22 deletions
diff --git a/modules/generators/config5.m4 b/modules/generators/config5.m4
index 3ffd19a5c3..da33140938 100644
--- a/modules/generators/config5.m4
+++ b/modules/generators/config5.m4
@@ -78,15 +78,4 @@ fi
APR_ADDTO(INCLUDES, [-I\$(top_srcdir)/$modpath_current])
-AC_ARG_ENABLE(cgid-fdpassing,
- [APACHE_HELP_STRING(--enable-cgid-fdpassing,Enable experimental mod_cgid support for fd passing)],
- [if test "$enableval" = "yes"; then
- AC_CHECK_DECL(CMSG_DATA,
- [AC_DEFINE([HAVE_CGID_FDPASSING], 1, [Enable FD passing support in mod_cgid])],
- [AC_MSG_ERROR([cannot support mod_cgid fd-passing on this system])], [
-#include <sys/types.h>
-#include <sys/socket.h>])
- fi
-])
-
APACHE_MODPATH_FINISH
diff --git a/modules/generators/mod_cgid.c b/modules/generators/mod_cgid.c
index b821b69b9a..1636ad41f1 100644
--- a/modules/generators/mod_cgid.c
+++ b/modules/generators/mod_cgid.c
@@ -218,7 +218,7 @@ typedef struct {
#define cgi_server_conf cgid_server_conf
#define cgi_module cgid_module
-#ifdef HAVE_CGID_FDPASSING
+#ifdef HAVE_FDPASSING
/* Pull in CGI bucket implementation. */
#define WANT_CGI_BUCKET
#endif
@@ -353,7 +353,7 @@ static apr_status_t close_unix_socket(void *thefd)
static apr_status_t sock_readhdr(int fd, int *errfd, void *vbuf, size_t buf_size)
{
int rc;
-#ifndef HAVE_CGID_FDPASSING
+#ifndef HAVE_FDPASSING
char *buf = vbuf;
size_t bytes_read = 0;
@@ -458,7 +458,7 @@ static apr_status_t sock_writev(int fd, int auxfd, request_rec *r, int count, ..
}
va_end(ap);
-#ifndef HAVE_CGID_FDPASSING
+#ifndef HAVE_FDPASSING
do {
rc = writev(fd, vec, count);
} while (rc < 0 && errno == EINTR);
@@ -1541,7 +1541,7 @@ static int cgid_handler(request_rec *r)
}
*/
-#ifdef HAVE_CGID_FDPASSING
+#ifdef HAVE_FDPASSING
rv = apr_file_pipe_create(&script_err, &errpipe_out, r->pool);
if (rv) {
return log_scripterror(r, conf, HTTP_SERVICE_UNAVAILABLE, rv, APLOGNO(10176),
@@ -1623,7 +1623,7 @@ static int cgid_handler(request_rec *r)
shutdown(sd, 1);
bb = apr_brigade_create(r->pool, c->bucket_alloc);
-#ifdef HAVE_CGID_FDPASSING
+#ifdef HAVE_FDPASSING
b = cgi_bucket_create(r, dc->timeout, tempsock, script_err, c->bucket_alloc);
if (b == NULL)
return HTTP_INTERNAL_SERVER_ERROR; /* should call log_scripterror() w/ _UNAVAILABLE? */
diff --git a/modules/proxy/config.m4 b/modules/proxy/config.m4
index d9bfd7a1ce..34346a6698 100644
--- a/modules/proxy/config.m4
+++ b/modules/proxy/config.m4
@@ -40,12 +40,7 @@ APACHE_MODULE(proxy_fcgi, Apache proxy FastCGI module. Requires --enable-proxy.
APACHE_MODULE(proxy_scgi, Apache proxy SCGI module. Requires --enable-proxy., $proxy_scgi_objs, , most, , proxy)
APACHE_MODULE(proxy_uwsgi, Apache proxy UWSGI module. Requires --enable-proxy., $proxy_uwsgi_objs, , most, , proxy)
APACHE_MODULE(proxy_fdpass, Apache proxy to Unix Daemon Socket module. Requires --enable-proxy., $proxy_fdpass_objs, , most, [
- AC_CHECK_DECL(CMSG_DATA,,, [
- #include <sys/types.h>
- #include <sys/socket.h>
- ])
- if test $ac_cv_have_decl_CMSG_DATA = "no"; then
- AC_MSG_WARN([Your system does not support CMSG_DATA.])
+ if test $ap_has_fdpassing = 0; then
enable_proxy_fdpass=no
fi
],proxy)