Commit 61860508 authored by Steven Hartland's avatar Steven Hartland Committed by Brad Fitzpatrick

net/http/cgi: make provided Env override even system env vars

Allow all CGI environment settings from the inherited set and default
inherited set to be overridden including PATH by Env.

Change-Id: Ief8d33247b879fa87a8bfd6416d4813116db98de
Reviewed-on: https://go-review.googlesource.com/14959Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
parent 1d765b77
...@@ -159,10 +159,6 @@ func (h *Handler) ServeHTTP(rw http.ResponseWriter, req *http.Request) { ...@@ -159,10 +159,6 @@ func (h *Handler) ServeHTTP(rw http.ResponseWriter, req *http.Request) {
env = append(env, "CONTENT_TYPE="+ctype) env = append(env, "CONTENT_TYPE="+ctype)
} }
if h.Env != nil {
env = append(env, h.Env...)
}
envPath := os.Getenv("PATH") envPath := os.Getenv("PATH")
if envPath == "" { if envPath == "" {
envPath = "/bin:/usr/bin:/usr/ucb:/usr/bsd:/usr/local/bin" envPath = "/bin:/usr/bin:/usr/ucb:/usr/bsd:/usr/local/bin"
...@@ -181,6 +177,10 @@ func (h *Handler) ServeHTTP(rw http.ResponseWriter, req *http.Request) { ...@@ -181,6 +177,10 @@ func (h *Handler) ServeHTTP(rw http.ResponseWriter, req *http.Request) {
} }
} }
if h.Env != nil {
env = append(env, h.Env...)
}
env = removeLeadingDuplicates(env) env = removeLeadingDuplicates(env)
var cwd, path string var cwd, path string
......
...@@ -487,12 +487,14 @@ func TestEnvOverride(t *testing.T) { ...@@ -487,12 +487,14 @@ func TestEnvOverride(t *testing.T) {
Args: []string{cgifile}, Args: []string{cgifile},
Env: []string{ Env: []string{
"SCRIPT_FILENAME=" + cgifile, "SCRIPT_FILENAME=" + cgifile,
"REQUEST_URI=/foo/bar"}, "REQUEST_URI=/foo/bar",
"PATH=/wibble"},
} }
expectedMap := map[string]string{ expectedMap := map[string]string{
"cwd": cwd, "cwd": cwd,
"env-SCRIPT_FILENAME": cgifile, "env-SCRIPT_FILENAME": cgifile,
"env-REQUEST_URI": "/foo/bar", "env-REQUEST_URI": "/foo/bar",
"env-PATH": "/wibble",
} }
runCgiTest(t, h, "GET /test.cgi HTTP/1.0\nHost: example.com\n\n", expectedMap) runCgiTest(t, h, "GET /test.cgi HTTP/1.0\nHost: example.com\n\n", expectedMap)
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment