config.go — fiber Source File
Architecture documentation for config.go, a go file in the fiber codebase. 1 imports, 0 dependents.
Entity Profile
Dependency Diagram
graph LR 4385628f_9f64_45c8_f2f6_b3f8531ce1ae["config.go"] d31b53b2_3d0c_f538_f920_e1ae643c437c["time"] 4385628f_9f64_45c8_f2f6_b3f8531ce1ae --> d31b53b2_3d0c_f538_f920_e1ae643c437c style 4385628f_9f64_45c8_f2f6_b3f8531ce1ae fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
package limiter
import (
"time"
"github.com/gofiber/fiber/v3"
)
const defaultLimiterMax = 5
// Config defines the config for middleware.
type Config struct {
// Store is used to store the state of the middleware
//
// Default: an in memory store for this process only
Storage fiber.Storage
// LimiterMiddleware is the struct that implements a limiter middleware.
//
// Default: a new Fixed Window Rate Limiter
LimiterMiddleware Handler
// Next defines a function to skip this middleware when returned true.
//
// Optional. Default: nil
Next func(c fiber.Ctx) bool
// A function to dynamically calculate the max requests supported by the rate limiter middleware
//
// Default: func(c fiber.Ctx) int {
// return c.Max
// }
MaxFunc func(c fiber.Ctx) int
// A function to dynamically calculate the expiration time for rate limiter entries
//
// Default: A function that returns the static `Expiration` value from the config.
ExpirationFunc func(c fiber.Ctx) time.Duration
// KeyGenerator allows you to generate custom keys, by default c.IP() is used
//
// Default: func(c fiber.Ctx) string {
// return c.IP()
// }
KeyGenerator func(fiber.Ctx) string
// LimitReached is called when a request hits the limit
//
// Default: func(c fiber.Ctx) error {
// return c.SendStatus(fiber.StatusTooManyRequests)
// }
LimitReached fiber.Handler
// Max number of recent connections during `Expiration` seconds before sending a 429 response
//
// Default: 5
Max int
// Expiration is the time on how long to keep records of requests in memory
//
// Default: 1 * time.Minute
// ... (87 more lines)
Domain
Subdomains
Functions
Classes
Types
Dependencies
- time
Source
Frequently Asked Questions
What does config.go do?
config.go is a source file in the fiber codebase, written in go. It belongs to the FiberMiddleware domain, Session subdomain.
What functions are defined in config.go?
config.go defines 5 function(s): bool, c, configDefault, int, string.
What does config.go depend on?
config.go imports 1 module(s): time.
Where is config.go in the architecture?
config.go is located at middleware/limiter/config.go (domain: FiberMiddleware, subdomain: Session, directory: middleware/limiter).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free