summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorsemarie <semarie@openbsd.org>2015-07-20 11:38:19 +0000
committersemarie <semarie@openbsd.org>2015-07-20 11:38:19 +0000
commitc81abcf104e627a48b22cd48f74c7671b8795b01 (patch)
treed3fe85e70f31267084dee1ff4beb8e4b9633d480
parentCorrect the tsl/fsl sequence to ]0 not ]2 (from Marcel Korpel). While (diff)
downloadwireguard-openbsd-c81abcf104e627a48b22cd48f74c7671b8795b01.tar.xz
wireguard-openbsd-c81abcf104e627a48b22cd48f74c7671b8795b01.zip
ensure http_path is escaped before using it in Location redirection.
OK reyk@
-rw-r--r--usr.sbin/httpd/server_file.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/usr.sbin/httpd/server_file.c b/usr.sbin/httpd/server_file.c
index 9fd9ef20b05..e79a5ce3527 100644
--- a/usr.sbin/httpd/server_file.c
+++ b/usr.sbin/httpd/server_file.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: server_file.c,v 1.58 2015/07/18 14:36:24 kili Exp $ */
+/* $OpenBSD: server_file.c,v 1.59 2015/07/20 11:38:19 semarie Exp $ */
/*
* Copyright (c) 2006 - 2015 Reyk Floeter <reyk@openbsd.org>
@@ -66,7 +66,7 @@ server_file_access(struct httpd *env, struct client *clt,
struct server_config *srv_conf = clt->clt_srv_conf;
struct stat st;
struct kv *r, key;
- char *newpath;
+ char *newpath, *encodedpath;
int ret;
errno = 0;
@@ -90,10 +90,16 @@ server_file_access(struct httpd *env, struct client *clt,
/* Redirect to path with trailing "/" */
if (path[strlen(path) - 1] != '/') {
+ if ((encodedpath = url_encode(desc->http_path)) == NULL)
+ return (500);
if (asprintf(&newpath, "http%s://%s%s/",
srv_conf->flags & SRVFLAG_TLS ? "s" : "",
- desc->http_host, desc->http_path) == -1)
+ desc->http_host, encodedpath) == -1) {
+ free(encodedpath);
return (500);
+ }
+ free(encodedpath);
+
/* Path alias will be used for the redirection */
desc->http_path_alias = newpath;