2020-11-11 14:03:16 +01:00
|
|
|
package requestid
|
|
|
|
|
|
|
|
import (
|
2022-05-31 17:35:49 +03:00
|
|
|
"github.com/gofiber/fiber/v3"
|
2022-10-31 13:44:53 +00:00
|
|
|
"github.com/gofiber/utils/v2"
|
2020-11-11 14:03:16 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// Config defines the config for middleware.
|
|
|
|
type Config struct {
|
|
|
|
// Next defines a function to skip this middleware when returned true.
|
|
|
|
//
|
|
|
|
// Optional. Default: nil
|
2022-07-13 08:48:29 +03:00
|
|
|
Next func(c fiber.Ctx) bool
|
2020-11-11 14:03:16 +01:00
|
|
|
|
|
|
|
// Header is the header key where to get/set the unique request ID
|
|
|
|
//
|
|
|
|
// Optional. Default: "X-Request-ID"
|
|
|
|
Header string
|
|
|
|
|
|
|
|
// Generator defines a function to generate the unique identifier.
|
|
|
|
//
|
|
|
|
// Optional. Default: utils.UUID
|
|
|
|
Generator func() string
|
|
|
|
|
|
|
|
// ContextKey defines the key used when storing the request ID in
|
|
|
|
// the locals for a specific request.
|
|
|
|
//
|
|
|
|
// Optional. Default: requestid
|
2023-03-14 18:37:10 +00:00
|
|
|
ContextKey interface{}
|
2020-11-11 14:03:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// ConfigDefault is the default config
|
2022-12-01 09:11:14 +01:00
|
|
|
// It uses a fast UUID generator which will expose the number of
|
|
|
|
// requests made to the server. To conceal this value for better
|
|
|
|
// privacy, use the "utils.UUIDv4" generator.
|
2020-11-11 14:03:16 +01:00
|
|
|
var ConfigDefault = Config{
|
|
|
|
Next: nil,
|
|
|
|
Header: fiber.HeaderXRequestID,
|
|
|
|
Generator: utils.UUID,
|
|
|
|
ContextKey: "requestid",
|
|
|
|
}
|
|
|
|
|
|
|
|
// Helper function to set default values
|
|
|
|
func configDefault(config ...Config) Config {
|
|
|
|
// Return default config if nothing provided
|
|
|
|
if len(config) < 1 {
|
|
|
|
return ConfigDefault
|
|
|
|
}
|
|
|
|
|
|
|
|
// Override default config
|
|
|
|
cfg := config[0]
|
|
|
|
|
|
|
|
// Set default values
|
|
|
|
if cfg.Header == "" {
|
|
|
|
cfg.Header = ConfigDefault.Header
|
|
|
|
}
|
|
|
|
if cfg.Generator == nil {
|
|
|
|
cfg.Generator = ConfigDefault.Generator
|
|
|
|
}
|
|
|
|
if cfg.ContextKey == "" {
|
|
|
|
cfg.ContextKey = ConfigDefault.ContextKey
|
|
|
|
}
|
|
|
|
return cfg
|
|
|
|
}
|