caddy/config/middleware.go

56 lines
1.7 KiB
Go
Raw Normal View History

package config
import (
"github.com/mholt/caddy/middleware"
"github.com/mholt/caddy/middleware/extensionless"
"github.com/mholt/caddy/middleware/fastcgi"
"github.com/mholt/caddy/middleware/gzip"
"github.com/mholt/caddy/middleware/headers"
"github.com/mholt/caddy/middleware/log"
"github.com/mholt/caddy/middleware/proxy"
"github.com/mholt/caddy/middleware/redirect"
"github.com/mholt/caddy/middleware/rewrite"
2015-03-03 17:49:45 +01:00
"github.com/mholt/caddy/middleware/websockets"
)
// This init function registers middleware. Register middleware
// in the order they should be executed during a request.
2015-02-08 06:17:15 +01:00
// Middleware execute in this order: A-B-C-*-C-B-A
func init() {
register("gzip", gzip.New)
register("header", headers.New)
register("log", log.New)
register("rewrite", rewrite.New)
register("redirect", redirect.New)
register("ext", extensionless.New)
register("proxy", proxy.New)
register("fastcgi", fastcgi.New)
2015-03-03 17:49:45 +01:00
register("websocket", websockets.New)
}
var (
// registry stores the registered middleware:
// both the order and the directives to which they
// are bound.
registry = struct {
directiveMap map[string]middleware.Generator
2015-02-08 06:17:15 +01:00
ordered []string
}{
directiveMap: make(map[string]middleware.Generator),
}
)
// register binds a middleware generator (outer function)
// to a directive. Upon each request, middleware will be
// executed in the order they are registered.
func register(directive string, generator middleware.Generator) {
registry.directiveMap[directive] = generator
2015-02-08 06:17:15 +01:00
registry.ordered = append(registry.ordered, directive)
}
// middlewareRegistered returns whether or not a directive is registered.
func middlewareRegistered(directive string) bool {
_, ok := registry.directiveMap[directive]
return ok
}