mirror of
https://github.com/gofiber/fiber.git
synced 2025-02-23 06:23:39 +00:00
94 lines
2.8 KiB
Go
94 lines
2.8 KiB
Go
package middleware
|
|
|
|
import (
|
|
"fmt"
|
|
"log"
|
|
|
|
fiber "github.com/gofiber/fiber"
|
|
fasthttp "github.com/valyala/fasthttp"
|
|
)
|
|
|
|
// CompressConfig defines the config for Compress middleware.
|
|
type CompressConfig struct {
|
|
// Next defines a function to skip this middleware if returned true.
|
|
Next func(ctx *fiber.Ctx) bool
|
|
// Compression level for brotli, gzip and deflate
|
|
Level int
|
|
}
|
|
|
|
// Compression levels determine the compression complexity
|
|
const (
|
|
CompressLevelDisabled = -1
|
|
CompressLevelDefault = 0
|
|
CompressLevelBestSpeed = 1
|
|
CompressLevelBestCompression = 2
|
|
)
|
|
|
|
// CompressConfigDefault is the default config
|
|
var CompressConfigDefault = CompressConfig{
|
|
Next: nil,
|
|
Level: CompressLevelDefault,
|
|
}
|
|
|
|
/*
|
|
Compress allows the following config arguments in any order:
|
|
- Compress()
|
|
- Compress(next func(*fiber.Ctx) bool)
|
|
- Compress(level int)
|
|
- Compress(config CompressConfig)
|
|
*/
|
|
func Compress(options ...interface{}) fiber.Handler {
|
|
// Create default config
|
|
var config = CompressConfigDefault
|
|
// Assert options if provided to adjust the config
|
|
if len(options) > 0 {
|
|
for i := range options {
|
|
switch opt := options[i].(type) {
|
|
case func(*fiber.Ctx) bool:
|
|
config.Next = opt
|
|
case int:
|
|
config.Level = opt
|
|
case CompressConfig:
|
|
config = opt
|
|
default:
|
|
log.Fatal("Compress: the following option types are allowed: int, func(*fiber.Ctx) bool, CompressConfig")
|
|
}
|
|
}
|
|
}
|
|
// Return CompressWithConfig
|
|
return compress(config)
|
|
}
|
|
|
|
// CompressWithConfig is deprecated, please use Compress instead
|
|
func CompressWithConfig(config CompressConfig) fiber.Handler {
|
|
fmt.Println("compress: `CompressWithConfig()` is deprecated since v1.12.4, please use `Compress()`")
|
|
return compress(config)
|
|
}
|
|
|
|
func compress(config CompressConfig) fiber.Handler {
|
|
// Init middleware settings
|
|
var compressHandler fasthttp.RequestHandler
|
|
switch config.Level {
|
|
case -1: // Disabled
|
|
compressHandler = fasthttp.CompressHandlerBrotliLevel(func(c *fasthttp.RequestCtx) {}, fasthttp.CompressBrotliNoCompression, fasthttp.CompressNoCompression)
|
|
case 1: // Best speed
|
|
compressHandler = fasthttp.CompressHandlerBrotliLevel(func(c *fasthttp.RequestCtx) {}, fasthttp.CompressBrotliBestSpeed, fasthttp.CompressBestSpeed)
|
|
case 2: // Best compression
|
|
compressHandler = fasthttp.CompressHandlerBrotliLevel(func(c *fasthttp.RequestCtx) {}, fasthttp.CompressBrotliBestCompression, fasthttp.CompressBestCompression)
|
|
default: // Default
|
|
compressHandler = fasthttp.CompressHandlerBrotliLevel(func(c *fasthttp.RequestCtx) {}, fasthttp.CompressBrotliDefaultCompression, fasthttp.CompressDefaultCompression)
|
|
}
|
|
// Return handler
|
|
return func(c *fiber.Ctx) {
|
|
// Don't execute the middleware if Next returns false
|
|
if config.Next != nil && config.Next(c) {
|
|
c.Next()
|
|
return
|
|
}
|
|
// Middleware logic...
|
|
c.Next()
|
|
// Compress response
|
|
compressHandler(c.Fasthttp)
|
|
}
|
|
}
|