48 lines
1.1 KiB
Go
48 lines
1.1 KiB
Go
package middlewares
|
|
|
|
import (
|
|
"strconv"
|
|
"time"
|
|
|
|
"github.com/valyala/fasthttp"
|
|
|
|
"github.com/authelia/authelia/v4/internal/metrics"
|
|
)
|
|
|
|
// NewMetricsRequest returns a middleware if provided with a metrics.Recorder, otherwise it returns nil.
|
|
func NewMetricsRequest(metrics metrics.Recorder) (middleware Basic) {
|
|
if metrics == nil {
|
|
return nil
|
|
}
|
|
|
|
return func(next fasthttp.RequestHandler) (handler fasthttp.RequestHandler) {
|
|
return func(ctx *fasthttp.RequestCtx) {
|
|
started := time.Now()
|
|
|
|
next(ctx)
|
|
|
|
statusCode := strconv.Itoa(ctx.Response.StatusCode())
|
|
requestMethod := string(ctx.Method())
|
|
|
|
metrics.RecordRequest(statusCode, requestMethod, time.Since(started))
|
|
}
|
|
}
|
|
}
|
|
|
|
// NewMetricsAuthzRequest returns a middleware if provided with a metrics.Recorder, otherwise it returns nil.
|
|
func NewMetricsAuthzRequest(metrics metrics.Recorder) (middleware Basic) {
|
|
if metrics == nil {
|
|
return nil
|
|
}
|
|
|
|
return func(next fasthttp.RequestHandler) (handler fasthttp.RequestHandler) {
|
|
return func(ctx *fasthttp.RequestCtx) {
|
|
next(ctx)
|
|
|
|
statusCode := strconv.Itoa(ctx.Response.StatusCode())
|
|
|
|
metrics.RecordAuthz(statusCode)
|
|
}
|
|
}
|
|
}
|