diff options
author | Alan Pearce | 2024-07-03 10:35:12 +0200 |
---|---|---|
committer | Alan Pearce | 2024-07-03 10:37:05 +0200 |
commit | c4c67c0f3a07ebed224dfc9de4c93d10c47f149a (patch) | |
tree | 1d5b72522b18206d6b786d1ea6279eb47dd5bd9d /internal/server/server.go | |
parent | 336ddaf703ec403661ee3d588512934019ff9b5c (diff) | |
download | website-c4c67c0f3a07ebed224dfc9de4c93d10c47f149a.tar.lz website-c4c67c0f3a07ebed224dfc9de4c93d10c47f149a.tar.zst website-c4c67c0f3a07ebed224dfc9de4c93d10c47f149a.zip |
make HTTP->S redirects use same host only for HSTS
Diffstat (limited to 'internal/server/server.go')
-rw-r--r-- | internal/server/server.go | 26 |
1 files changed, 8 insertions, 18 deletions
diff --git a/internal/server/server.go b/internal/server/server.go index ba5effe..b174c0c 100644 --- a/internal/server/server.go +++ b/internal/server/server.go @@ -46,10 +46,9 @@ type Config struct { type Server struct { *http.Server - redirectServer *http.Server - runtimeConfig *Config - config *cfg.Config - log *log.Logger + runtimeConfig *Config + config *cfg.Config + log *log.Logger } func applyDevModeOverrides(config *cfg.Config, runtimeConfig *Config) { @@ -184,15 +183,13 @@ func New(runtimeConfig *Config, log *log.Logger) (*Server, error) { return nil, errors.Wrap(err, "could not create website mux") } - rMux := http.NewServeMux() - rMux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { - path, _ := website.CanonicalisePath(r.URL.Path) - newURL := config.BaseURL.JoinPath(path) - http.Redirect(w, r, newURL.String(), 301) - }) if runtimeConfig.Redirect { loggingMux.Handle(config.BaseURL.Hostname()+"/", mux) - loggingMux.Handle("/", rMux) + loggingMux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { + path, _ := website.CanonicalisePath(r.URL.Path) + newURL := config.BaseURL.JoinPath(path) + http.Redirect(w, r, newURL.String(), http.StatusMovedPermanently) + }) } else { loggingMux.Handle("/", mux) } @@ -215,13 +212,6 @@ func New(runtimeConfig *Config, log *log.Logger) (*Server, error) { IdleTimeout: 10 * time.Minute, Handler: top, }, - redirectServer: &http.Server{ - ReadHeaderTimeout: 10 * time.Second, - ReadTimeout: 1 * time.Minute, - WriteTimeout: 2 * time.Minute, - IdleTimeout: 10 * time.Minute, - Handler: rMux, - }, log: log, config: config, runtimeConfig: runtimeConfig, |