Commit 9e4eeb4f authored by Nathan Caza's avatar Nathan Caza Committed by Matt Holt

Add proxyprotocol directive and listener middleware plugin type (#1349)

* add support for listener middleware

* add proxyprotocol directive

* make caddy.Listener interface required

* Remove tcpKeepAliveListener wrapper from Serve()
This is now done in the Listen() function, along with other potential middleware.
parent c62b6b9f
...@@ -6,6 +6,8 @@ import ( ...@@ -6,6 +6,8 @@ import (
"os" "os"
"path" "path"
"time" "time"
"github.com/mholt/caddy"
) )
func init() { func init() {
...@@ -18,6 +20,10 @@ type ( ...@@ -18,6 +20,10 @@ type (
// passed the next Handler in the chain. // passed the next Handler in the chain.
Middleware func(Handler) Handler Middleware func(Handler) Handler
// ListenerMiddleware is similar to the Middleware type, except it
// chains one net.Listener to the next.
ListenerMiddleware func(caddy.Listener) caddy.Listener
// Handler is like http.Handler except ServeHTTP may return a status // Handler is like http.Handler except ServeHTTP may return a status
// code and/or error. // code and/or error.
// //
......
...@@ -445,6 +445,9 @@ var directives = []string{ ...@@ -445,6 +445,9 @@ var directives = []string{
"realip", // github.com/captncraig/caddy-realip "realip", // github.com/captncraig/caddy-realip
"git", // github.com/abiosoft/caddy-git "git", // github.com/abiosoft/caddy-git
// directives that add listener middleware to the stack
"proxyprotocol", // github.com/mastercactapus/caddy-proxyprotocol
// directives that add middleware to the stack // directives that add middleware to the stack
"locale", // github.com/simia-tech/caddy-locale "locale", // github.com/simia-tech/caddy-locale
"log", "log",
......
...@@ -215,9 +215,20 @@ func (s *Server) Listen() (net.Listener, error) { ...@@ -215,9 +215,20 @@ func (s *Server) Listen() (net.Listener, error) {
} }
} }
if tcpLn, ok := ln.(*net.TCPListener); ok {
ln = tcpKeepAliveListener{TCPListener: tcpLn}
}
cln := ln.(caddy.Listener)
for _, site := range s.sites {
for _, m := range site.listenerMiddleware {
cln = m(cln)
}
}
// Very important to return a concrete caddy.Listener // Very important to return a concrete caddy.Listener
// implementation for graceful restarts. // implementation for graceful restarts.
return ln.(*net.TCPListener), nil return cln.(caddy.Listener), nil
} }
// ListenPacket creates udp connection for QUIC if it is enabled, // ListenPacket creates udp connection for QUIC if it is enabled,
...@@ -234,10 +245,6 @@ func (s *Server) ListenPacket() (net.PacketConn, error) { ...@@ -234,10 +245,6 @@ func (s *Server) ListenPacket() (net.PacketConn, error) {
// Serve serves requests on ln. It blocks until ln is closed. // Serve serves requests on ln. It blocks until ln is closed.
func (s *Server) Serve(ln net.Listener) error { func (s *Server) Serve(ln net.Listener) error {
if tcpLn, ok := ln.(*net.TCPListener); ok {
ln = tcpKeepAliveListener{TCPListener: tcpLn}
}
s.listenerMu.Lock() s.listenerMu.Lock()
s.listener = ln s.listener = ln
s.listenerMu.Unlock() s.listenerMu.Unlock()
......
...@@ -25,6 +25,9 @@ type SiteConfig struct { ...@@ -25,6 +25,9 @@ type SiteConfig struct {
// Compiled middleware stack // Compiled middleware stack
middlewareChain Handler middlewareChain Handler
// listener middleware stack
listenerMiddleware []ListenerMiddleware
// Directory from which to serve files // Directory from which to serve files
Root string Root string
...@@ -80,6 +83,11 @@ func (s *SiteConfig) AddMiddleware(m Middleware) { ...@@ -80,6 +83,11 @@ func (s *SiteConfig) AddMiddleware(m Middleware) {
s.middleware = append(s.middleware, m) s.middleware = append(s.middleware, m)
} }
// AddListenerMiddleware adds a listener middleware to a site's listenerMiddleware stack.
func (s *SiteConfig) AddListenerMiddleware(l ListenerMiddleware) {
s.listenerMiddleware = append(s.listenerMiddleware, l)
}
// TLSConfig returns s.TLS. // TLSConfig returns s.TLS.
func (s SiteConfig) TLSConfig() *caddytls.Config { func (s SiteConfig) TLSConfig() *caddytls.Config {
return s.TLS return s.TLS
...@@ -99,3 +107,8 @@ func (s SiteConfig) Port() string { ...@@ -99,3 +107,8 @@ func (s SiteConfig) Port() string {
func (s SiteConfig) Middleware() []Middleware { func (s SiteConfig) Middleware() []Middleware {
return s.middleware return s.middleware
} }
// ListenerMiddleware returns s.listenerMiddleware
func (s SiteConfig) ListenerMiddleware() []ListenerMiddleware {
return s.listenerMiddleware
}
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