Commit 35e309cf authored by Matthew Holt's avatar Matthew Holt

First use of OncePerServerBlock in a Setup function

startup and shutdown commands should only be executed once per appearance in the Caddyfile (naturally meaning once per server block).

Notice that we support multiple occurrences of startup and shutdown in the same server block by building the callback array incrementally as we parse the Caddyfile, then we append all the callbacks all at once. Quite literally, the OncePerServerBlock function executes only once per server block!
parent e0fdddc7
...@@ -20,6 +20,8 @@ func Shutdown(c *Controller) (middleware.Middleware, error) { ...@@ -20,6 +20,8 @@ func Shutdown(c *Controller) (middleware.Middleware, error) {
// using c to parse the line. It appends the callback function // using c to parse the line. It appends the callback function
// to the list of callback functions passed in by reference. // to the list of callback functions passed in by reference.
func registerCallback(c *Controller, list *[]func() error) error { func registerCallback(c *Controller, list *[]func() error) error {
var funcs []func() error
for c.Next() { for c.Next() {
args := c.RemainingArgs() args := c.RemainingArgs()
if len(args) == 0 { if len(args) == 0 {
...@@ -50,8 +52,12 @@ func registerCallback(c *Controller, list *[]func() error) error { ...@@ -50,8 +52,12 @@ func registerCallback(c *Controller, list *[]func() error) error {
return cmd.Run() return cmd.Run()
} }
*list = append(*list, fn) funcs = append(funcs, fn)
} }
c.OncePerServerBlock(func() {
*list = append(*list, funcs...)
})
return nil return nil
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment