func AccessHandler(f func(r *http.Request, status, size int, duration time.Duration)) func(next http.Handler) http.Handler
AccessHandler returns a handler that call f after each request.
func CtxWithID(ctx context.Context, id xid.ID) context.Context
CtxWithID adds the given xid.ID to the context
func CustomHeaderHandler(fieldKey, header string) func(next http.Handler) http.Handler
CustomHeaderHandler adds given header from request's header as a field to the context's logger using fieldKey as field key.
func FromRequest(r *http.Request) *zerolog.Logger
FromRequest gets the logger in the request's context. This is a shortcut for log.Ctx(r.Context())
func IDFromCtx(ctx context.Context) (id xid.ID, ok bool)
IDFromCtx returns the unique id associated to the context if any.
func IDFromRequest(r *http.Request) (id xid.ID, ok bool)
IDFromRequest returns the unique id associated to the request if any.
func MethodHandler(fieldKey string) func(next http.Handler) http.Handler
MethodHandler adds the request method as a field to the context's logger using fieldKey as field key.
func NewHandler(log zerolog.Logger) func(http.Handler) http.Handler
NewHandler injects log into requests context.
func ProtoHandler(fieldKey string) func(next http.Handler) http.Handler
ProtoHandler adds the requests protocol version as a field to the context logger using fieldKey as field Key.
func RefererHandler(fieldKey string) func(next http.Handler) http.Handler
RefererHandler adds the request's referer as a field to the context's logger using fieldKey as field key.
func RemoteAddrHandler(fieldKey string) func(next http.Handler) http.Handler
RemoteAddrHandler adds the request's remote address as a field to the context's logger using fieldKey as field key.
func RequestHandler(fieldKey string) func(next http.Handler) http.Handler
RequestHandler adds the request method and URL as a field to the context's logger using fieldKey as field key.
func RequestIDHandler(fieldKey, headerName string) func(next http.Handler) http.Handler
RequestIDHandler returns a handler setting a unique id to the request which can be gathered using IDFromRequest(req). This generated id is added as a field to the logger using the passed fieldKey as field name. The id is also added as a response header if the headerName is not empty.
The generated id is a URL safe base64 encoded mongo object-id-like unique id. Mongo unique id generation algorithm has been selected as a trade-off between size and ease of use: UUID is less space efficient and snowflake requires machine configuration.
func URLHandler(fieldKey string) func(next http.Handler) http.Handler
URLHandler adds the requested URL as a field to the context's logger using fieldKey as field key.
func UserAgentHandler(fieldKey string) func(next http.Handler) http.Handler
UserAgentHandler adds the request's user-agent as a field to the context's logger using fieldKey as field key.
Name | Synopsis |
---|---|
.. |