Adding upstream version 2.52.6.
Signed-off-by: Daniel Baumann <daniel@debian.org>
This commit is contained in:
parent
a960158181
commit
6d002e9543
441 changed files with 95392 additions and 0 deletions
125
middleware/idempotency/config.go
Normal file
125
middleware/idempotency/config.go
Normal file
|
@ -0,0 +1,125 @@
|
|||
package idempotency
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"fmt"
|
||||
"time"
|
||||
|
||||
"github.com/gofiber/fiber/v2"
|
||||
"github.com/gofiber/fiber/v2/internal/storage/memory"
|
||||
)
|
||||
|
||||
var ErrInvalidIdempotencyKey = errors.New("invalid idempotency key")
|
||||
|
||||
// Config defines the config for middleware.
|
||||
type Config struct {
|
||||
// Next defines a function to skip this middleware when returned true.
|
||||
//
|
||||
// Optional. Default: a function which skips the middleware on safe HTTP request method.
|
||||
Next func(c *fiber.Ctx) bool
|
||||
|
||||
// Lifetime is the maximum lifetime of an idempotency key.
|
||||
//
|
||||
// Optional. Default: 30 * time.Minute
|
||||
Lifetime time.Duration
|
||||
|
||||
// KeyHeader is the name of the header that contains the idempotency key.
|
||||
//
|
||||
// Optional. Default: X-Idempotency-Key
|
||||
KeyHeader string
|
||||
// KeyHeaderValidate defines a function to validate the syntax of the idempotency header.
|
||||
//
|
||||
// Optional. Default: a function which ensures the header is 36 characters long (the size of an UUID).
|
||||
KeyHeaderValidate func(string) error
|
||||
|
||||
// KeepResponseHeaders is a list of headers that should be kept from the original response.
|
||||
//
|
||||
// Optional. Default: nil (to keep all headers)
|
||||
KeepResponseHeaders []string
|
||||
|
||||
// Lock locks an idempotency key.
|
||||
//
|
||||
// Optional. Default: an in-memory locker for this process only.
|
||||
Lock Locker
|
||||
|
||||
// Storage stores response data by idempotency key.
|
||||
//
|
||||
// Optional. Default: an in-memory storage for this process only.
|
||||
Storage fiber.Storage
|
||||
}
|
||||
|
||||
// ConfigDefault is the default config
|
||||
var ConfigDefault = Config{
|
||||
Next: func(c *fiber.Ctx) bool {
|
||||
// Skip middleware if the request was done using a safe HTTP method
|
||||
return fiber.IsMethodSafe(c.Method())
|
||||
},
|
||||
|
||||
Lifetime: 30 * time.Minute,
|
||||
|
||||
KeyHeader: "X-Idempotency-Key",
|
||||
KeyHeaderValidate: func(k string) error {
|
||||
if l, wl := len(k), 36; l != wl { // UUID length is 36 chars
|
||||
return fmt.Errorf("%w: invalid length: %d != %d", ErrInvalidIdempotencyKey, l, wl)
|
||||
}
|
||||
|
||||
return nil
|
||||
},
|
||||
|
||||
KeepResponseHeaders: nil,
|
||||
|
||||
Lock: nil, // Set in configDefault so we don't allocate data here.
|
||||
|
||||
Storage: nil, // Set in configDefault so we don't allocate data here.
|
||||
}
|
||||
|
||||
// Helper function to set default values
|
||||
func configDefault(config ...Config) Config {
|
||||
// Return default config if nothing provided
|
||||
if len(config) < 1 {
|
||||
cfg := ConfigDefault
|
||||
|
||||
cfg.Lock = NewMemoryLock()
|
||||
cfg.Storage = memory.New(memory.Config{
|
||||
GCInterval: cfg.Lifetime / 2, // Half the lifetime interval
|
||||
})
|
||||
|
||||
return cfg
|
||||
}
|
||||
|
||||
// Override default config
|
||||
cfg := config[0]
|
||||
|
||||
// Set default values
|
||||
|
||||
if cfg.Next == nil {
|
||||
cfg.Next = ConfigDefault.Next
|
||||
}
|
||||
|
||||
if cfg.Lifetime.Nanoseconds() == 0 {
|
||||
cfg.Lifetime = ConfigDefault.Lifetime
|
||||
}
|
||||
|
||||
if cfg.KeyHeader == "" {
|
||||
cfg.KeyHeader = ConfigDefault.KeyHeader
|
||||
}
|
||||
if cfg.KeyHeaderValidate == nil {
|
||||
cfg.KeyHeaderValidate = ConfigDefault.KeyHeaderValidate
|
||||
}
|
||||
|
||||
if cfg.KeepResponseHeaders != nil && len(cfg.KeepResponseHeaders) == 0 {
|
||||
cfg.KeepResponseHeaders = ConfigDefault.KeepResponseHeaders
|
||||
}
|
||||
|
||||
if cfg.Lock == nil {
|
||||
cfg.Lock = NewMemoryLock()
|
||||
}
|
||||
|
||||
if cfg.Storage == nil {
|
||||
cfg.Storage = memory.New(memory.Config{
|
||||
GCInterval: cfg.Lifetime / 2, // Half the lifetime interval
|
||||
})
|
||||
}
|
||||
|
||||
return cfg
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue