]> granicus.if.org Git - apache/commitdiff
Fail startup for vhost configuration problems, rather than
authorDaniel Earl Poirier <poirier@apache.org>
Mon, 30 Aug 2010 16:09:50 +0000 (16:09 +0000)
committerDaniel Earl Poirier <poirier@apache.org>
Mon, 30 Aug 2010 16:09:50 +0000 (16:09 +0000)
running with a configuration with undefined behavior.

git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@990844 13f79535-47bb-0310-9956-ffa450edef68

CHANGES
server/vhost.c

diff --git a/CHANGES b/CHANGES
index 783238cae6fe908cc2d9fb8ffa32dcc47fdca41f..199d5beb16ecdc0e2be73d0ea19428b565ae2b13 100644 (file)
--- a/CHANGES
+++ b/CHANGES
@@ -2,6 +2,14 @@
 
 Changes with Apache 2.3.9
 
+  *) vhosts: Do not allow _default_ in NameVirtualHost, or mixing *
+     and non-* ports on NameVirtualHost, or multiple NameVirtualHost
+     directives for the same address:port, or NameVirtualHost
+     directives with no matching VirtualHosts, or multiple ip-based
+     VirtualHost sections for the same address:port.  These were
+     previously accepted with a warning, but the behavior was
+     undefined.  [Dan Poirier]
+
   *) mod_remoteip: Fix a segfaulti when using mod_remoteip in conjunction with
      Allow/Deny. PR 49838.  [Andrew Skalski <voltara gmail.com>]
 
index 5684605b96693ca0a021e29a6570f8b57308d012..e6d4229a1927c0e17c72cf91c8765ace2cf37d0b 100644 (file)
@@ -97,6 +97,13 @@ static ipaddr_chain *default_list;
 static server_addr_rec *name_vhost_list;
 static server_addr_rec **name_vhost_list_tail;
 
+/* whether a config error was seen */
+static int config_error = 0;
+
+/* config check function */
+static int vhost_check_config(apr_pool_t *p, apr_pool_t *plog,
+                              apr_pool_t *ptemp, server_rec *s);
+
 /*
  * How it's used:
  *
@@ -127,6 +134,7 @@ AP_DECLARE(void) ap_init_vhost_config(apr_pool_t *p)
     default_list = NULL;
     name_vhost_list = NULL;
     name_vhost_list_tail = &name_vhost_list;
+    ap_hook_check_config(vhost_check_config, NULL, NULL, APR_HOOK_MIDDLE);
 }
 
 
@@ -255,6 +263,11 @@ AP_DECLARE_NONSTD(const char *)ap_set_name_virtual_host(cmd_parms *cmd,
                                                         void *dummy,
                                                         const char *arg)
 {
+    if (0 == strcasecmp(arg, "_default_")
+        || 0 == strncasecmp(arg, "_default_:", 10)) {
+        return "_default_ is not allowed in NameVirtualHost directive";
+    }
+
     /* use whatever port the main server has at this point */
     return get_addresses(cmd->pool, arg, &name_vhost_list_tail,
                          cmd->server->port);
@@ -510,9 +523,9 @@ static int add_name_vhost_config(apr_pool_t *p, server_rec *main_s,
             ap_log_error(APLOG_MARK, APLOG_ERR, 0, main_s,
                          "VirtualHost %s:%u -- mixing * "
                          "ports and non-* ports with "
-                         "a NameVirtualHost address is not supported,"
-                         " proceeding with undefined results",
+                         "a NameVirtualHost address is not supported",
                          sar->virthost, sar->host_port);
+            config_error = 1;
         }
         return 1;
     }
@@ -528,11 +541,12 @@ static void remove_unused_name_vhosts(server_rec *main_s, ipaddr_chain **pic)
         ipaddr_chain *ic = *pic;
 
         if (ic->server == NULL) {
-            ap_log_error(APLOG_MARK, APLOG_WARNING, 0, main_s,
+            ap_log_error(APLOG_MARK, APLOG_ERR, 0, main_s,
                          "Either NameVirtualHost %s:%u has no VirtualHosts,"
                          " or there is more than one identical NameVirtualHost line,"
                          " or your VirtualHost declarations do not match the NameVirtualHost line",
                          ic->sar->virthost, ic->sar->host_port);
+            config_error = 1;
             *pic = ic->next;
         }
         else {
@@ -610,10 +624,10 @@ AP_DECLARE(void) ap_fini_vhost_config(apr_pool_t *p, server_rec *main_s)
                 ic = find_default_server(sar->host_port);
                 if (!ic || !add_name_vhost_config(p, main_s, s, sar, ic)) {
                     if (ic && ic->sar->host_port != 0) {
-                        ap_log_error(APLOG_MARK, APLOG_WARNING,
+                        ap_log_error(APLOG_MARK, APLOG_ERR,
                                      0, main_s, "_default_ VirtualHost "
-                                     "overlap on port %u, the first has "
-                                     "precedence", sar->host_port);
+                                     "overlap on port %u", sar->host_port);
+                        config_error = 1;
                     }
                     ic = new_ipaddr_chain(p, s, sar);
                     ic->next = default_list;
@@ -633,13 +647,14 @@ AP_DECLARE(void) ap_fini_vhost_config(apr_pool_t *p, server_rec *main_s)
                     *iphash_table_tail[bucket] = ic;
                 }
                 else if (!add_name_vhost_config(p, main_s, s, sar, ic)) {
-                    ap_log_error(APLOG_MARK, APLOG_WARNING,
+                    ap_log_error(APLOG_MARK, APLOG_ERR,
                                  0, main_s, "VirtualHost %s:%u overlaps "
                                  "with VirtualHost %s:%u, the first has "
                                  "precedence, perhaps you need a "
                                  "NameVirtualHost directive",
                                  sar->virthost, sar->host_port,
                                  ic->sar->virthost, ic->sar->host_port);
+                    config_error = 1;
                     ic->sar = sar;
                     ic->server = s;
                 }
@@ -706,6 +721,11 @@ AP_DECLARE(void) ap_fini_vhost_config(apr_pool_t *p, server_rec *main_s)
     }
 }
 
+static int vhost_check_config(apr_pool_t *p, apr_pool_t *plog,
+                              apr_pool_t *ptemp, server_rec *s)
+{
+    return config_error ? !OK : OK;
+}
 
 /*****************************************************************************
  * run-time vhost matching functions