Commit 727ef243 authored by Matthew Holt's avatar Matthew Holt

Improve godoc for plugin facilities

parent d3860f95
...@@ -88,14 +88,30 @@ type serverListener struct { ...@@ -88,14 +88,30 @@ type serverListener struct {
listener net.Listener listener net.Listener
} }
// Context is a type that carries a server type through // Context is a type which carries a server type through
// the load and setup phase; it maintains the state // the load and setup phase; it maintains the state
// between loading the Caddyfile, then executing its // between loading the Caddyfile, then executing its
// directives, then making the servers for Caddy to // directives, then making the servers for Caddy to
// manage. Typically, such state involves configuration // manage. Typically, such state involves configuration
// structs, etc. // structs, etc.
type Context interface { type Context interface {
// Called after the Caddyfile is parsed into server
// blocks but before the directives are executed,
// this method gives you an opportunity to inspect
// the server blocks and prepare for the execution
// of directives. Return the server blocks (which
// you may modify, if desired) and an error, if any.
// The first argument is the name or path to the
// configuration file (Caddyfile).
//
// This function can be a no-op and simply return its
// input if there is nothing to do here.
InspectServerBlocks(string, []caddyfile.ServerBlock) ([]caddyfile.ServerBlock, error) InspectServerBlocks(string, []caddyfile.ServerBlock) ([]caddyfile.ServerBlock, error)
// This is what Caddy calls to make server instances.
// By this time, all directives have been executed and,
// presumably, the context has enough state to produce
// server instances for Caddy to start.
MakeServers() ([]Server, error) MakeServers() ([]Server, error)
} }
...@@ -115,21 +131,18 @@ type ServerType struct { ...@@ -115,21 +131,18 @@ type ServerType struct {
// one word if possible and lower-cased. // one word if possible and lower-cased.
Directives []string Directives []string
// InspectServerBlocks is an optional callback that is
// executed after loading the tokens for each server
// block but before executing the directives in them.
// This func may modify the server blocks and return
// new ones to be used.
InspectServerBlocks func(sourceFile string, serverBlocks []caddyfile.ServerBlock) ([]caddyfile.ServerBlock, error)
// MakeServers is a callback that makes the server
// instances.
MakeServers func() ([]Server, error)
// DefaultInput returns a default config input if none // DefaultInput returns a default config input if none
// is otherwise loaded. // is otherwise loaded. This is optional, but highly
// recommended, otherwise a blank Caddyfile will be
// used.
DefaultInput func() Input DefaultInput func() Input
// The function that produces a new server type context.
// This will be called when a new Caddyfile is being
// loaded, parsed, and executed independently of any
// startup phases before this one. It's a way to keep
// each set of server instances separate and to reduce
// the amount of global state you need.
NewContext func() Context NewContext func() Context
} }
...@@ -216,12 +229,12 @@ func DirectiveAction(serverType, dir string) (SetupFunc, error) { ...@@ -216,12 +229,12 @@ func DirectiveAction(serverType, dir string) (SetupFunc, error) {
// loaders return a non-nil Input. The default // loaders return a non-nil Input. The default
// loader may always return an Input value. // loader may always return an Input value.
type Loader interface { type Loader interface {
Load(string) (Input, error) Load(serverType string) (Input, error)
} }
// LoaderFunc is a convenience type similar to http.HandlerFunc // LoaderFunc is a convenience type similar to http.HandlerFunc
// that allows you to use a plain function as a Load() method. // that allows you to use a plain function as a Load() method.
type LoaderFunc func(string) (Input, error) type LoaderFunc func(serverType string) (Input, error)
// Load loads a Caddyfile. // Load loads a Caddyfile.
func (lf LoaderFunc) Load(serverType string) (Input, error) { func (lf LoaderFunc) Load(serverType string) (Input, error) {
......
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