mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-28 12:55:57 +03:00
caddyhttp: Support configuring Server from handler provisioning (#4933)
* configuring http.Server from handlers. * Minor tweaks * Run gofmt Co-authored-by: Matthew Holt <mholt@users.noreply.github.com>
This commit is contained in:
parent
616418281b
commit
bffc258732
2 changed files with 54 additions and 1 deletions
|
@ -178,7 +178,9 @@ func (app *App) Provision(ctx caddy.Context) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// prepare each server
|
// prepare each server
|
||||||
|
oldContext := ctx.Context
|
||||||
for srvName, srv := range app.Servers {
|
for srvName, srv := range app.Servers {
|
||||||
|
ctx.Context = context.WithValue(oldContext, ServerCtxKey, srv)
|
||||||
srv.name = srvName
|
srv.name = srvName
|
||||||
srv.tlsApp = app.tlsApp
|
srv.tlsApp = app.tlsApp
|
||||||
srv.events = eventsAppIface.(*caddyevents.App)
|
srv.events = eventsAppIface.(*caddyevents.App)
|
||||||
|
@ -293,7 +295,7 @@ func (app *App) Provision(ctx caddy.Context) error {
|
||||||
srv.IdleTimeout = defaultIdleTimeout
|
srv.IdleTimeout = defaultIdleTimeout
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
ctx.Context = oldContext
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -365,6 +367,7 @@ func (app *App) Start() error {
|
||||||
// this TLS config is used by the std lib to choose the actual TLS config for connections
|
// this TLS config is used by the std lib to choose the actual TLS config for connections
|
||||||
// by looking through the connection policies to find the first one that matches
|
// by looking through the connection policies to find the first one that matches
|
||||||
tlsCfg := srv.TLSConnPolicies.TLSConfig(app.ctx)
|
tlsCfg := srv.TLSConnPolicies.TLSConfig(app.ctx)
|
||||||
|
srv.configureServer(srv.server)
|
||||||
|
|
||||||
// enable H2C if configured
|
// enable H2C if configured
|
||||||
if srv.protocol("h2c") {
|
if srv.protocol("h2c") {
|
||||||
|
|
|
@ -176,6 +176,11 @@ type Server struct {
|
||||||
|
|
||||||
shutdownAt time.Time
|
shutdownAt time.Time
|
||||||
shutdownAtMu *sync.RWMutex
|
shutdownAtMu *sync.RWMutex
|
||||||
|
|
||||||
|
// registered callback functions
|
||||||
|
connStateFuncs []func(net.Conn, http.ConnState)
|
||||||
|
connContextFuncs []func(ctx context.Context, c net.Conn) context.Context
|
||||||
|
onShutdownFuncs []func()
|
||||||
}
|
}
|
||||||
|
|
||||||
// ServeHTTP is the entry point for all HTTP requests.
|
// ServeHTTP is the entry point for all HTTP requests.
|
||||||
|
@ -513,6 +518,51 @@ func (s *Server) serveHTTP3(hostport string, tlsCfg *tls.Config) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// configureServer applies/binds the registered callback functions to the server.
|
||||||
|
func (s *Server) configureServer(server *http.Server) {
|
||||||
|
for _, f := range s.connStateFuncs {
|
||||||
|
if server.ConnState != nil {
|
||||||
|
baseConnStateFunc := server.ConnState
|
||||||
|
server.ConnState = func(conn net.Conn, state http.ConnState) {
|
||||||
|
baseConnStateFunc(conn, state)
|
||||||
|
f(conn, state)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
server.ConnState = f
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, f := range s.connContextFuncs {
|
||||||
|
if server.ConnContext != nil {
|
||||||
|
baseConnContextFunc := server.ConnContext
|
||||||
|
server.ConnContext = func(ctx context.Context, c net.Conn) context.Context {
|
||||||
|
return f(baseConnContextFunc(ctx, c), c)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
server.ConnContext = f
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, f := range s.onShutdownFuncs {
|
||||||
|
server.RegisterOnShutdown(f)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// RegisterConnState registers f to be invoked on s.ConnState.
|
||||||
|
func (s *Server) RegisterConnState(f func(net.Conn, http.ConnState)) {
|
||||||
|
s.connStateFuncs = append(s.connStateFuncs, f)
|
||||||
|
}
|
||||||
|
|
||||||
|
// RegisterConnContext registers f to be invoked as part of s.ConnContext.
|
||||||
|
func (s *Server) RegisterConnContext(f func(ctx context.Context, c net.Conn) context.Context) {
|
||||||
|
s.connContextFuncs = append(s.connContextFuncs, f)
|
||||||
|
}
|
||||||
|
|
||||||
|
// RegisterOnShutdown registers f to be invoked on server shutdown.
|
||||||
|
func (s *Server) RegisterOnShutdown(f func()) {
|
||||||
|
s.onShutdownFuncs = append(s.onShutdownFuncs, f)
|
||||||
|
}
|
||||||
|
|
||||||
// HTTPErrorConfig determines how to handle errors
|
// HTTPErrorConfig determines how to handle errors
|
||||||
// from the HTTP handlers.
|
// from the HTTP handlers.
|
||||||
type HTTPErrorConfig struct {
|
type HTTPErrorConfig struct {
|
||||||
|
|
Loading…
Reference in a new issue