Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
caddy
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
caddy
Commits
727ef243
Commit
727ef243
authored
Jun 06, 2016
by
Matthew Holt
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve godoc for plugin facilities
parent
d3860f95
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
15 deletions
+28
-15
plugins.go
plugins.go
+28
-15
No files found.
plugins.go
View file @
727ef243
...
@@ -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
(
s
erverType
s
tring
)
(
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
(
s
erverType
s
tring
)
(
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
)
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment