2023-06-19 23:42:47 +02:00
|
|
|
// SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
2018-11-12 19:23:39 +01:00
|
|
|
|
|
|
|
package httpd // import "miniflux.app/service/httpd"
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"miniflux.app/config"
|
|
|
|
"miniflux.app/http/request"
|
|
|
|
"miniflux.app/logger"
|
|
|
|
)
|
|
|
|
|
2019-06-02 03:18:09 +02:00
|
|
|
func middleware(next http.Handler) http.Handler {
|
2018-11-12 19:23:39 +01:00
|
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
clientIP := request.FindClientIP(r)
|
|
|
|
ctx := r.Context()
|
|
|
|
ctx = context.WithValue(ctx, request.ClientIPContextKey, clientIP)
|
|
|
|
|
|
|
|
if r.Header.Get("X-Forwarded-Proto") == "https" {
|
2019-06-02 03:18:09 +02:00
|
|
|
config.Opts.HTTPS = true
|
2018-11-12 19:23:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
protocol := "HTTP"
|
2019-06-02 03:18:09 +02:00
|
|
|
if config.Opts.HTTPS {
|
2018-11-12 19:23:39 +01:00
|
|
|
protocol = "HTTPS"
|
|
|
|
}
|
|
|
|
|
|
|
|
logger.Debug("[%s] %s %s %s", protocol, clientIP, r.Method, r.RequestURI)
|
|
|
|
|
2019-06-02 03:18:09 +02:00
|
|
|
if config.Opts.HTTPS && config.Opts.HasHSTS() {
|
2018-11-12 19:23:39 +01:00
|
|
|
w.Header().Set("Strict-Transport-Security", "max-age=31536000")
|
|
|
|
}
|
|
|
|
|
|
|
|
next.ServeHTTP(w, r.WithContext(ctx))
|
|
|
|
})
|
|
|
|
}
|