mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-25 03:25:54 +03:00
4ebff9a130
Merged config and app packages into one called caddy. Abstracted away caddy startup functionality making it easier to embed Caddy in any Go application and use it as a library. Graceful restart (should) now ensure child starts properly. Now piping a gob bundle to child process so that the child can match up inherited listeners to server address. Much cleanup still to do.
84 lines
1.5 KiB
Go
84 lines
1.5 KiB
Go
package setup
|
|
|
|
import (
|
|
"github.com/mholt/caddy/middleware"
|
|
"github.com/mholt/caddy/middleware/headers"
|
|
)
|
|
|
|
// Headers configures a new Headers middleware instance.
|
|
func Headers(c *Controller) (middleware.Middleware, error) {
|
|
rules, err := headersParse(c)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return func(next middleware.Handler) middleware.Handler {
|
|
return headers.Headers{Next: next, Rules: rules}
|
|
}, nil
|
|
}
|
|
|
|
func headersParse(c *Controller) ([]headers.Rule, error) {
|
|
var rules []headers.Rule
|
|
|
|
for c.NextLine() {
|
|
var head headers.Rule
|
|
var isNewPattern bool
|
|
|
|
if !c.NextArg() {
|
|
return rules, c.ArgErr()
|
|
}
|
|
pattern := c.Val()
|
|
|
|
// See if we already have a definition for this Path pattern...
|
|
for _, h := range rules {
|
|
if h.Path == pattern {
|
|
head = h
|
|
break
|
|
}
|
|
}
|
|
|
|
// ...otherwise, this is a new pattern
|
|
if head.Path == "" {
|
|
head.Path = pattern
|
|
isNewPattern = true
|
|
}
|
|
|
|
for c.NextBlock() {
|
|
// A block of headers was opened...
|
|
|
|
h := headers.Header{Name: c.Val()}
|
|
|
|
if c.NextArg() {
|
|
h.Value = c.Val()
|
|
}
|
|
|
|
head.Headers = append(head.Headers, h)
|
|
}
|
|
if c.NextArg() {
|
|
// ... or single header was defined as an argument instead.
|
|
|
|
h := headers.Header{Name: c.Val()}
|
|
|
|
h.Value = c.Val()
|
|
|
|
if c.NextArg() {
|
|
h.Value = c.Val()
|
|
}
|
|
|
|
head.Headers = append(head.Headers, h)
|
|
}
|
|
|
|
if isNewPattern {
|
|
rules = append(rules, head)
|
|
} else {
|
|
for i := 0; i < len(rules); i++ {
|
|
if rules[i].Path == pattern {
|
|
rules[i] = head
|
|
break
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return rules, nil
|
|
}
|