1
0
mirror of https://github.com/rclone/rclone.git synced 2025-01-13 20:38:12 +02:00

rc: fix misplaced http server config - fixes #4130

This commit is contained in:
Xiaoxing Ye 2020-04-24 03:22:47 +08:00 committed by GitHub
parent e56976839a
commit c4572ebc91
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -62,12 +62,7 @@ type Server struct {
} }
func newServer(opt *rc.Options, mux *http.ServeMux) *Server { func newServer(opt *rc.Options, mux *http.ServeMux) *Server {
s := &Server{ fileHandler := http.Handler(nil)
Server: httplib.NewServer(mux, &opt.HTTPOptions),
opt: opt,
}
mux.HandleFunc("/", s.handler)
// Add some more mime types which are often missing // Add some more mime types which are often missing
_ = mime.AddExtensionType(".wasm", "application/wasm") _ = mime.AddExtensionType(".wasm", "application/wasm")
_ = mime.AddExtensionType(".js", "application/javascript") _ = mime.AddExtensionType(".js", "application/javascript")
@ -80,7 +75,7 @@ func newServer(opt *rc.Options, mux *http.ServeMux) *Server {
fs.Logf(nil, "--rc-files overrides --rc-web-gui command\n") fs.Logf(nil, "--rc-files overrides --rc-web-gui command\n")
} }
fs.Logf(nil, "Serving files from %q", opt.Files) fs.Logf(nil, "Serving files from %q", opt.Files)
s.files = http.FileServer(http.Dir(opt.Files)) fileHandler = http.FileServer(http.Dir(opt.Files))
} else if opt.WebUI { } else if opt.WebUI {
if err := rc.CheckAndDownloadWebGUIRelease(opt.WebGUIUpdate, opt.WebGUIForceUpdate, opt.WebGUIFetchURL, config.CacheDir); err != nil { if err := rc.CheckAndDownloadWebGUIRelease(opt.WebGUIUpdate, opt.WebGUIForceUpdate, opt.WebGUIFetchURL, config.CacheDir); err != nil {
log.Fatalf("Error while fetching the latest release of Web GUI: %v", err) log.Fatalf("Error while fetching the latest release of Web GUI: %v", err)
@ -104,8 +99,16 @@ func newServer(opt *rc.Options, mux *http.ServeMux) *Server {
opt.Serve = true opt.Serve = true
fs.Logf(nil, "Serving Web GUI") fs.Logf(nil, "Serving Web GUI")
s.files = http.FileServer(http.Dir(extractPath)) fileHandler = http.FileServer(http.Dir(extractPath))
} }
s := &Server{
Server: httplib.NewServer(mux, &opt.HTTPOptions),
opt: opt,
files: fileHandler,
}
mux.HandleFunc("/", s.handler)
return s return s
} }