aboutsummaryrefslogtreecommitdiffstats
path: root/www/apache2
diff options
context:
space:
mode:
Diffstat (limited to 'www/apache2')
-rw-r--r--www/apache2/Makefile2
-rw-r--r--www/apache2/files/patch-server:protocol.c32
2 files changed, 33 insertions, 1 deletions
diff --git a/www/apache2/Makefile b/www/apache2/Makefile
index 54c9a1b8f766..f9a76626224a 100644
--- a/www/apache2/Makefile
+++ b/www/apache2/Makefile
@@ -9,7 +9,7 @@
PORTNAME= apache
PORTVERSION= 2.0.49
-PORTREVISION= 2
+PORTREVISION= 3
CATEGORIES= www ipv6
MASTER_SITES= ${MASTER_SITE_APACHE_HTTPD} \
http://sheepkiller.nerim.net/ports/${PORTNAME}/:powerlogo
diff --git a/www/apache2/files/patch-server:protocol.c b/www/apache2/files/patch-server:protocol.c
new file mode 100644
index 000000000000..96cd559e63d8
--- /dev/null
+++ b/www/apache2/files/patch-server:protocol.c
@@ -0,0 +1,32 @@
+===================================================================
+RCS file: /home/cvspublic/httpd-2.0/server/protocol.c,v
+retrieving revision 1.121.2.18
+retrieving revision 1.121.2.19
+diff -u -r1.121.2.18 -r1.121.2.19
+--- server/protocol.c 2004/06/11 20:46:41 1.121.2.18
++++ server/protocol.c 2004/06/28 23:57:14 1.121.2.19
+@@ -719,6 +719,23 @@
+ * continuations that span many many lines.
+ */
+ apr_size_t fold_len = last_len + len + 1; /* trailing null */
++
++ if ((fold_len - 1) > r->server->limit_req_fieldsize) {
++ r->status = HTTP_BAD_REQUEST;
++ /* report what we have accumulated so far before the
++ * overflow (last_field) as the field with the problem
++ */
++ apr_table_setn(r->notes, "error-notes",
++ apr_pstrcat(r->pool,
++ "Size of a request header field "
++ "after folding "
++ "exceeds server limit.<br />\n"
++ "<pre>\n",
++ ap_escape_html(r->pool, last_field),
++ "</pre>\n", NULL));
++ return;
++ }
++
+ if (fold_len > alloc_len) {
+ char *fold_buf;
+ alloc_len += alloc_len;
+