mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-06 22:40:31 -05:00
fastcgi: Set default root path; add interface guards
This commit is contained in:
parent
80b54f3b9d
commit
d2e46c2be0
2 changed files with 29 additions and 7 deletions
|
@ -76,6 +76,14 @@ func (Transport) CaddyModule() caddy.ModuleInfo {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Provision sets up t.
|
||||||
|
func (t *Transport) Provision(_ caddy.Context) error {
|
||||||
|
if t.Root == "" {
|
||||||
|
t.Root = "{http.var.root}"
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// RoundTrip implements http.RoundTripper.
|
// RoundTrip implements http.RoundTripper.
|
||||||
func (t Transport) RoundTrip(r *http.Request) (*http.Response, error) {
|
func (t Transport) RoundTrip(r *http.Request) (*http.Response, error) {
|
||||||
env, err := t.buildEnv(r)
|
env, err := t.buildEnv(r)
|
||||||
|
@ -136,6 +144,8 @@ func (t Transport) RoundTrip(r *http.Request) (*http.Response, error) {
|
||||||
|
|
||||||
// buildEnv returns a set of CGI environment variables for the request.
|
// buildEnv returns a set of CGI environment variables for the request.
|
||||||
func (t Transport) buildEnv(r *http.Request) (map[string]string, error) {
|
func (t Transport) buildEnv(r *http.Request) (map[string]string, error) {
|
||||||
|
repl := r.Context().Value(caddy.ReplacerCtxKey).(caddy.Replacer)
|
||||||
|
|
||||||
var env map[string]string
|
var env map[string]string
|
||||||
|
|
||||||
// Separate remote IP and port; more lenient than net.SplitHostPort
|
// Separate remote IP and port; more lenient than net.SplitHostPort
|
||||||
|
@ -151,6 +161,7 @@ func (t Transport) buildEnv(r *http.Request) (map[string]string, error) {
|
||||||
ip = strings.Replace(ip, "[", "", 1)
|
ip = strings.Replace(ip, "[", "", 1)
|
||||||
ip = strings.Replace(ip, "]", "", 1)
|
ip = strings.Replace(ip, "]", "", 1)
|
||||||
|
|
||||||
|
root := repl.ReplaceAll(t.Root, ".")
|
||||||
fpath := r.URL.Path
|
fpath := r.URL.Path
|
||||||
|
|
||||||
// Split path in preparation for env variables.
|
// Split path in preparation for env variables.
|
||||||
|
@ -167,7 +178,7 @@ func (t Transport) buildEnv(r *http.Request) (map[string]string, error) {
|
||||||
scriptName = strings.TrimSuffix(scriptName, pathInfo)
|
scriptName = strings.TrimSuffix(scriptName, pathInfo)
|
||||||
|
|
||||||
// SCRIPT_FILENAME is the absolute path of SCRIPT_NAME
|
// SCRIPT_FILENAME is the absolute path of SCRIPT_NAME
|
||||||
scriptFilename := filepath.Join(t.Root, scriptName)
|
scriptFilename := filepath.Join(root, scriptName)
|
||||||
|
|
||||||
// Add vhost path prefix to scriptName. Otherwise, some PHP software will
|
// Add vhost path prefix to scriptName. Otherwise, some PHP software will
|
||||||
// have difficulty discovering its URL.
|
// have difficulty discovering its URL.
|
||||||
|
@ -208,13 +219,13 @@ func (t Transport) buildEnv(r *http.Request) (map[string]string, error) {
|
||||||
"REMOTE_USER": "", // TODO: once there are authentication handlers, populate this
|
"REMOTE_USER": "", // TODO: once there are authentication handlers, populate this
|
||||||
"REQUEST_METHOD": r.Method,
|
"REQUEST_METHOD": r.Method,
|
||||||
"REQUEST_SCHEME": requestScheme,
|
"REQUEST_SCHEME": requestScheme,
|
||||||
"SERVER_NAME": t.ServerName,
|
"SERVER_NAME": t.serverName,
|
||||||
"SERVER_PORT": t.ServerPort,
|
"SERVER_PORT": t.serverPort,
|
||||||
"SERVER_PROTOCOL": r.Proto,
|
"SERVER_PROTOCOL": r.Proto,
|
||||||
"SERVER_SOFTWARE": t.SoftwareName + "/" + t.SoftwareVersion,
|
"SERVER_SOFTWARE": t.softwareName + "/" + t.softwareVersion,
|
||||||
|
|
||||||
// Other variables
|
// Other variables
|
||||||
"DOCUMENT_ROOT": t.Root,
|
"DOCUMENT_ROOT": root,
|
||||||
"DOCUMENT_URI": docURI,
|
"DOCUMENT_URI": docURI,
|
||||||
"HTTP_HOST": r.Host, // added here, since not always part of headers
|
"HTTP_HOST": r.Host, // added here, since not always part of headers
|
||||||
"REQUEST_URI": reqURL.RequestURI(),
|
"REQUEST_URI": reqURL.RequestURI(),
|
||||||
|
@ -226,7 +237,7 @@ func (t Transport) buildEnv(r *http.Request) (map[string]string, error) {
|
||||||
// PATH_TRANSLATED should only exist if PATH_INFO is defined.
|
// PATH_TRANSLATED should only exist if PATH_INFO is defined.
|
||||||
// Info: https://www.ietf.org/rfc/rfc3875 Page 14
|
// Info: https://www.ietf.org/rfc/rfc3875 Page 14
|
||||||
if env["PATH_INFO"] != "" {
|
if env["PATH_INFO"] != "" {
|
||||||
env["PATH_TRANSLATED"] = filepath.Join(t.Root, pathInfo) // Info: http://www.oreilly.com/openbook/cgi/ch02_04.html
|
env["PATH_TRANSLATED"] = filepath.Join(root, pathInfo) // Info: http://www.oreilly.com/openbook/cgi/ch02_04.html
|
||||||
}
|
}
|
||||||
|
|
||||||
// Some web apps rely on knowing HTTPS or not
|
// Some web apps rely on knowing HTTPS or not
|
||||||
|
@ -248,7 +259,6 @@ func (t Transport) buildEnv(r *http.Request) (map[string]string, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add env variables from config (with support for placeholders in values)
|
// Add env variables from config (with support for placeholders in values)
|
||||||
repl := r.Context().Value(caddy.ReplacerCtxKey).(caddy.Replacer)
|
|
||||||
for _, envVar := range t.EnvVars {
|
for _, envVar := range t.EnvVars {
|
||||||
env[envVar[0]] = repl.ReplaceAll(envVar[1], "")
|
env[envVar[0]] = repl.ReplaceAll(envVar[1], "")
|
||||||
}
|
}
|
||||||
|
@ -283,3 +293,9 @@ var tlsProtocolStrings = map[uint16]string{
|
||||||
}
|
}
|
||||||
|
|
||||||
var headerNameReplacer = strings.NewReplacer(" ", "_", "-", "_")
|
var headerNameReplacer = strings.NewReplacer(" ", "_", "-", "_")
|
||||||
|
|
||||||
|
// Interface guards
|
||||||
|
var (
|
||||||
|
_ caddy.Provisioner = (*Transport)(nil)
|
||||||
|
_ http.RoundTripper = (*Transport)(nil)
|
||||||
|
)
|
||||||
|
|
|
@ -200,3 +200,9 @@ type KeepAlive struct {
|
||||||
MaxIdleConnsPerHost int `json:"max_idle_conns_per_host,omitempty"`
|
MaxIdleConnsPerHost int `json:"max_idle_conns_per_host,omitempty"`
|
||||||
IdleConnTimeout caddy.Duration `json:"idle_timeout,omitempty"` // how long should connections be kept alive when idle
|
IdleConnTimeout caddy.Duration `json:"idle_timeout,omitempty"` // how long should connections be kept alive when idle
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Interface guards
|
||||||
|
var (
|
||||||
|
_ caddy.Provisioner = (*HTTPTransport)(nil)
|
||||||
|
_ http.RoundTripper = (*HTTPTransport)(nil)
|
||||||
|
)
|
||||||
|
|
Loading…
Reference in a new issue