2017-02-14 04:54:11 +01:00
|
|
|
package logger
|
|
|
|
|
2017-07-16 12:58:10 +02:00
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
2019-10-25 00:27:02 +02:00
|
|
|
"github.com/kataras/iris/v12/context"
|
2017-07-16 12:58:10 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// The SkipperFunc signature, used to serve the main request without logs.
|
|
|
|
// See `Configuration` too.
|
2020-07-10 22:21:09 +02:00
|
|
|
type SkipperFunc func(ctx *context.Context) bool
|
2017-07-16 12:58:10 +02:00
|
|
|
|
2017-07-17 16:42:51 +02:00
|
|
|
// Config contains the options for the logger middleware
|
|
|
|
// can be optionally be passed to the `New`.
|
2017-02-14 04:54:11 +01:00
|
|
|
type Config struct {
|
2017-07-17 16:42:51 +02:00
|
|
|
// Status displays status code (bool).
|
2017-07-16 12:58:10 +02:00
|
|
|
//
|
2017-07-17 16:42:51 +02:00
|
|
|
// Defaults to true.
|
2017-02-14 04:54:11 +01:00
|
|
|
Status bool
|
2017-07-17 16:42:51 +02:00
|
|
|
// IP displays request's remote address (bool).
|
2017-07-16 12:58:10 +02:00
|
|
|
//
|
2017-07-17 16:42:51 +02:00
|
|
|
// Defaults to true.
|
2017-02-14 04:54:11 +01:00
|
|
|
IP bool
|
2017-07-17 16:42:51 +02:00
|
|
|
// Method displays the http method (bool).
|
2017-07-16 12:58:10 +02:00
|
|
|
//
|
2017-07-17 16:42:51 +02:00
|
|
|
// Defaults to true.
|
2017-02-14 04:54:11 +01:00
|
|
|
Method bool
|
2017-07-17 16:42:51 +02:00
|
|
|
// Path displays the request path (bool).
|
2017-07-16 12:58:10 +02:00
|
|
|
//
|
2017-07-17 16:42:51 +02:00
|
|
|
// Defaults to true.
|
2017-02-14 04:54:11 +01:00
|
|
|
Path bool
|
2017-07-17 16:42:51 +02:00
|
|
|
|
2018-05-31 00:39:23 +02:00
|
|
|
// Query will append the URL Query to the Path.
|
|
|
|
// Path should be true too.
|
|
|
|
//
|
|
|
|
// Defaults to false.
|
|
|
|
Query bool
|
|
|
|
|
2017-07-30 18:47:50 +02:00
|
|
|
// Columns will display the logs as a formatted columns-rows text (bool).
|
2017-07-16 12:58:10 +02:00
|
|
|
// If custom `LogFunc` has been provided then this field is useless and users should
|
2017-07-22 21:57:20 +02:00
|
|
|
// use the `Columinize` function of the logger to get the output result as columns.
|
2017-07-16 12:58:10 +02:00
|
|
|
//
|
2017-07-30 18:47:50 +02:00
|
|
|
// Defaults to false.
|
2017-07-16 12:58:10 +02:00
|
|
|
Columns bool
|
2017-07-17 16:42:51 +02:00
|
|
|
|
2018-03-26 09:50:33 +02:00
|
|
|
// MessageContextKeys if not empty,
|
2017-07-17 16:42:51 +02:00
|
|
|
// the middleware will try to fetch
|
|
|
|
// the contents with `ctx.Values().Get(MessageContextKey)`
|
|
|
|
// and if available then these contents will be
|
|
|
|
// appended as part of the logs (with `%v`, in order to be able to set a struct too),
|
2019-06-07 20:07:08 +02:00
|
|
|
// if Columns field was set to true then
|
2017-07-17 16:42:51 +02:00
|
|
|
// a new column will be added named 'Message'.
|
|
|
|
//
|
|
|
|
// Defaults to empty.
|
2018-03-26 09:50:33 +02:00
|
|
|
MessageContextKeys []string
|
|
|
|
|
|
|
|
// MessageHeaderKeys if not empty,
|
|
|
|
// the middleware will try to fetch
|
|
|
|
// the contents with `ctx.Values().Get(MessageHeaderKey)`
|
|
|
|
// and if available then these contents will be
|
|
|
|
// appended as part of the logs (with `%v`, in order to be able to set a struct too),
|
2019-06-07 20:07:08 +02:00
|
|
|
// if Columns field was set to true then
|
2018-03-26 09:50:33 +02:00
|
|
|
// a new column will be added named 'HeaderMessage'.
|
|
|
|
//
|
|
|
|
// Defaults to empty.
|
|
|
|
MessageHeaderKeys []string
|
2017-07-17 16:42:51 +02:00
|
|
|
|
2017-07-16 12:58:10 +02:00
|
|
|
// LogFunc is the writer which logs are written to,
|
|
|
|
// if missing the logger middleware uses the app.Logger().Infof instead.
|
2017-07-17 16:42:51 +02:00
|
|
|
// Note that message argument can be empty.
|
2019-06-21 18:43:25 +02:00
|
|
|
LogFunc func(endTime time.Time, latency time.Duration, status, ip, method, path string, message interface{}, headerMessage interface{})
|
|
|
|
// LogFuncCtx can be used instead of `LogFunc` if handlers need to customize the output based on
|
|
|
|
// custom request-time information that the LogFunc isn't aware of.
|
2020-07-10 22:21:09 +02:00
|
|
|
LogFuncCtx func(ctx *context.Context, latency time.Duration)
|
2017-07-16 12:58:10 +02:00
|
|
|
// Skippers used to skip the logging i.e by `ctx.Path()` and serve
|
|
|
|
// the next/main handler immediately.
|
|
|
|
Skippers []SkipperFunc
|
|
|
|
// the Skippers as one function in order to reduce the time needed to
|
|
|
|
// combine them at serve time.
|
|
|
|
skip SkipperFunc
|
2017-02-14 04:54:11 +01:00
|
|
|
}
|
|
|
|
|
2017-07-17 16:42:51 +02:00
|
|
|
// DefaultConfig returns a default config
|
2017-07-30 18:47:50 +02:00
|
|
|
// that have all boolean fields to true except `Columns`,
|
2017-07-17 16:42:51 +02:00
|
|
|
// all strings are empty,
|
|
|
|
// LogFunc and Skippers to nil as well.
|
|
|
|
func DefaultConfig() Config {
|
|
|
|
return Config{
|
2019-06-21 18:43:25 +02:00
|
|
|
Status: true,
|
|
|
|
IP: true,
|
|
|
|
Method: true,
|
|
|
|
Path: true,
|
|
|
|
Query: false,
|
|
|
|
Columns: false,
|
|
|
|
LogFunc: nil,
|
|
|
|
LogFuncCtx: nil,
|
|
|
|
Skippers: nil,
|
|
|
|
skip: nil,
|
2017-07-17 16:42:51 +02:00
|
|
|
}
|
2017-07-16 12:58:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// AddSkipper adds a skipper to the configuration.
|
|
|
|
func (c *Config) AddSkipper(sk SkipperFunc) {
|
|
|
|
c.Skippers = append(c.Skippers, sk)
|
|
|
|
c.buildSkipper()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *Config) buildSkipper() {
|
|
|
|
if len(c.Skippers) == 0 {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
skippersLocked := c.Skippers[0:]
|
2020-07-10 22:21:09 +02:00
|
|
|
c.skip = func(ctx *context.Context) bool {
|
2017-07-16 12:58:10 +02:00
|
|
|
for _, s := range skippersLocked {
|
|
|
|
if s(ctx) {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
2017-02-14 04:54:11 +01:00
|
|
|
}
|