2024-01-02 16:40:06 +01:00
|
|
|
package server
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
"time"
|
|
|
|
|
2024-01-03 16:45:47 +01:00
|
|
|
"github.com/rs/zerolog/log"
|
2024-01-02 16:40:06 +01:00
|
|
|
ptypes "github.com/traefik/paerser/types"
|
|
|
|
)
|
|
|
|
|
|
|
|
func newKeepAliveMiddleware(next http.Handler, maxRequests int, maxTime ptypes.Duration) http.Handler {
|
|
|
|
return http.HandlerFunc(func(rw http.ResponseWriter, req *http.Request) {
|
|
|
|
state, ok := req.Context().Value(connStateKey).(*connState)
|
|
|
|
if ok {
|
|
|
|
state.HTTPRequestCount++
|
|
|
|
if maxRequests > 0 && state.HTTPRequestCount >= maxRequests {
|
2024-01-03 16:45:47 +01:00
|
|
|
log.Debug().Msg("Close because of too many requests")
|
2024-01-02 16:40:06 +01:00
|
|
|
state.KeepAliveState = "Close because of too many requests"
|
|
|
|
rw.Header().Set("Connection", "close")
|
|
|
|
}
|
|
|
|
if maxTime > 0 && time.Now().After(state.Start.Add(time.Duration(maxTime))) {
|
2024-01-03 16:45:47 +01:00
|
|
|
log.Debug().Msg("Close because of too long connection")
|
2024-01-02 16:40:06 +01:00
|
|
|
state.KeepAliveState = "Close because of too long connection"
|
|
|
|
rw.Header().Set("Connection", "close")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
next.ServeHTTP(rw, req)
|
|
|
|
})
|
|
|
|
}
|