From 989725ac16f4846c15033cf661c078d9ebf68dfa Mon Sep 17 00:00:00 2001 From: "alpha.wong" Date: Wed, 4 Jul 2018 12:16:38 +0800 Subject: [PATCH] FIX: Missing HSTS-header --- gddo-server/main.go | 5 +++-- httputil/middleware.go | 14 ++++++++++++++ httputil/middleware_test.go | 23 +++++++++++++++++++++++ 3 files changed, 40 insertions(+), 2 deletions(-) create mode 100644 httputil/middleware.go create mode 100644 httputil/middleware_test.go diff --git a/gddo-server/main.go b/gddo-server/main.go index 2137cb99..baa5848f 100644 --- a/gddo-server/main.go +++ b/gddo-server/main.go @@ -1016,8 +1016,9 @@ func main() { } } }() - http.Handle("/", s) - log.Fatal(http.ListenAndServe(s.v.GetString(ConfigBindAddress), s)) + ss := httputil.HSTS(s) + http.Handle("/", ss) + log.Fatal(http.ListenAndServe(s.v.GetString(ConfigBindAddress), ss)) } // removeInternal removes the internal packages from the given package diff --git a/httputil/middleware.go b/httputil/middleware.go new file mode 100644 index 00000000..20ce4700 --- /dev/null +++ b/httputil/middleware.go @@ -0,0 +1,14 @@ +package httputil + +import "net/http" + +func HSTS(next http.Handler) http.Handler { + return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + // This enforces the use of HTTPS for 1 year, including present and future subdomains. + // Chrome and Mozilla Firefox maintain an HSTS preload list + // that automatically informs the browser that the website can only be accessed through HTTPS. + // issue : https://github.com/golang/go/issues/26162 + w.Header().Set("Strict-Transport-Security", "max-age=31536000; includeSubDomains; preload") + next.ServeHTTP(w, r) + }) +} diff --git a/httputil/middleware_test.go b/httputil/middleware_test.go new file mode 100644 index 00000000..590fc924 --- /dev/null +++ b/httputil/middleware_test.go @@ -0,0 +1,23 @@ +package httputil + +import ( + "io" + "net/http" + "net/http/httptest" + "testing" +) + +func TestHSTS(t *testing.T) { + req := httptest.NewRequest(http.MethodGet, "/", nil) + respRecorder := httptest.NewRecorder() + handler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + io.WriteString(w, "") + }) + handlerWithMiddlewareHSTS := HSTS(handler) + handlerWithMiddlewareHSTS.ServeHTTP(respRecorder, req) + want := "max-age=31536000; includeSubDomains; preload" + got := respRecorder.Header().Get("Strict-Transport-Security") + if got != want { + t.Error("middlewareHSTS do not add HSTS header") + } +}