| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- // Copyright 2018 Frédéric Guillot. All rights reserved.
- // Use of this source code is governed by the Apache 2.0
- // license that can be found in the LICENSE file.
- package httpd // import "miniflux.app/service/httpd"
- import (
- "context"
- "net/http"
- "miniflux.app/config"
- "miniflux.app/http/request"
- "miniflux.app/logger"
- )
- type middleware struct {
- cfg *config.Config
- }
- func newMiddleware(cfg *config.Config) *middleware {
- return &middleware{cfg}
- }
- func (m *middleware) Serve(next http.Handler) http.Handler {
- 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" {
- m.cfg.IsHTTPS = true
- }
- protocol := "HTTP"
- if m.cfg.IsHTTPS {
- protocol = "HTTPS"
- }
- logger.Debug("[%s] %s %s %s", protocol, clientIP, r.Method, r.RequestURI)
- if m.cfg.IsHTTPS && m.cfg.HasHSTS() {
- w.Header().Set("Strict-Transport-Security", "max-age=31536000")
- }
- next.ServeHTTP(w, r.WithContext(ctx))
- })
- }
|