From abeb337f45126c0b532469dfac62a3ac41ba1489 Mon Sep 17 00:00:00 2001 From: Matthew Holt Date: Sat, 11 Apr 2015 16:58:34 -0600 Subject: [PATCH] Refactored rewrite middleware --- main.go | 4 +-- middleware/rewrite/rewrite.go | 58 ++++++++++++++++++++++------------- 2 files changed, 39 insertions(+), 23 deletions(-) diff --git a/main.go b/main.go index 6d9945a4..e5a953c2 100644 --- a/main.go +++ b/main.go @@ -16,7 +16,7 @@ var ( func init() { flag.StringVar(&conf, "conf", server.DefaultConfigFile, "the configuration file to use") - flag.BoolVar(&http2, "http2", true, "enable HTTP/2 support") // flag temporary until http2 merged into std lib + flag.BoolVar(&http2, "http2", true, "enable HTTP/2 support") // temporary flag until http2 merged into std lib } func main() { @@ -38,7 +38,7 @@ func main() { if err != nil { log.Fatal(err) } - s.HTTP2 = http2 + s.HTTP2 = http2 // TODO: This setting is temporary wg.Add(1) go func(s *server.Server) { defer wg.Done() diff --git a/middleware/rewrite/rewrite.go b/middleware/rewrite/rewrite.go index cfb39142..9ce9381e 100644 --- a/middleware/rewrite/rewrite.go +++ b/middleware/rewrite/rewrite.go @@ -8,42 +8,58 @@ import ( "github.com/mholt/caddy/middleware" ) -// New instantiates a new rewrite middleware. +// New instantiates a new Rewrites middleware. func New(c middleware.Controller) (middleware.Middleware, error) { - var rewrites []rewrite + rewrites, err := parse(c) + if err != nil { + return nil, err + } + + return func(next middleware.Handler) middleware.Handler { + return Rewrite{Next: next, Rules: rewrites} + }, nil +} + +// Rewrite is middleware to rewrite request locations internally before being handled. +type Rewrite struct { + Next middleware.Handler + Rules []RewriteRule +} + +// ServeHTTP implements the middleware.Handler interface. +func (rw Rewrite) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) { + for _, rule := range rw.Rules { + if r.URL.Path == rule.From { + r.URL.Path = rule.To + break + } + } + return rw.Next.ServeHTTP(w, r) +} + +func parse(c middleware.Controller) ([]RewriteRule, error) { + var rewrites []RewriteRule for c.Next() { - var rule rewrite + var rule RewriteRule if !c.NextArg() { - return nil, c.ArgErr() + return rewrites, c.ArgErr() } rule.From = c.Val() if !c.NextArg() { - return nil, c.ArgErr() + return rewrites, c.ArgErr() } rule.To = c.Val() rewrites = append(rewrites, rule) } - // TODO: Why can't we just return an http.Handler here instead? - return func(next middleware.Handler) middleware.Handler { - return middleware.HandlerFunc(func(w http.ResponseWriter, r *http.Request) (int, error) { - for _, rule := range rewrites { - if r.URL.Path == rule.From { - r.URL.Path = rule.To - break - } - } - return next.ServeHTTP(w, r) - }) - }, nil + return rewrites, nil } -// rewrite describes an internal location rewrite rule. -type rewrite struct { - From string - To string +// RewriteRule describes an internal location rewrite rule. +type RewriteRule struct { + From, To string }