diff options
author | Dmitry Patsura <[email protected]> | 2019-06-20 13:08:34 +0300 |
---|---|---|
committer | Dmitry Patsura <[email protected]> | 2019-06-20 13:08:34 +0300 |
commit | fddaca06c683654cb86934f38681c30188acbbf5 (patch) | |
tree | 64b7bfc36f9e49a45473fae33744975b977d26f4 /service/http | |
parent | 85126b000d140efdd99573e44241ee1e8b84d3c5 (diff) |
Feature(http): Introduce support for customResponseHeaders/customRequestHeaders by headers middleware
Diffstat (limited to 'service/http')
-rw-r--r-- | service/http/config.go | 20 | ||||
-rw-r--r-- | service/http/service.go | 31 |
2 files changed, 51 insertions, 0 deletions
diff --git a/service/http/config.go b/service/http/config.go index 5454f124..2b8cf049 100644 --- a/service/http/config.go +++ b/service/http/config.go @@ -33,10 +33,26 @@ type Config struct { // HTTP2 configuration HTTP2 *HTTP2Config + // Middlewares + Middlewares *MiddlewaresConfig + // Workers configures rr server and worker pool. Workers *roadrunner.ServerConfig } +type MiddlewaresConfig struct { + Headers *HeaderMiddlewareConfig +} + +type HeaderMiddlewareConfig struct { + CustomRequestHeaders map[string]string + CustomResponseHeaders map[string]string +} + +func (c *MiddlewaresConfig) EnableHeaders() bool { + return c.Headers.CustomRequestHeaders != nil || c.Headers.CustomResponseHeaders != nil +} + type FCGIConfig struct { // Port and port to handle as http server. Address string @@ -73,6 +89,10 @@ func (c *Config) EnableHTTP() bool { return c.Address != "" } +func (c *Config) EnableMiddlewares() bool { + return c.Middlewares != nil +} + // EnableTLS returns true if rr must listen TLS connections. func (c *Config) EnableTLS() bool { return c.SSL.Key != "" || c.SSL.Cert != "" diff --git a/service/http/service.go b/service/http/service.go index 00d877ec..59e7dd5a 100644 --- a/service/http/service.go +++ b/service/http/service.go @@ -95,6 +95,10 @@ func (s *Service) Serve() error { s.rr.Attach(s.controller) } + if s.cfg.EnableMiddlewares() { + s.initMiddlewares() + } + s.handler = &Handler{cfg: s.cfg, rr: s.rr} s.handler.Listen(s.throw) @@ -247,3 +251,30 @@ func (s *Service) tlsAddr(host string, forcePort bool) string { return host } + +func (s *Service) headersMiddleware(f http.HandlerFunc) http.HandlerFunc { + // Define the http.HandlerFunc + return func(w http.ResponseWriter, r *http.Request) { + if s.cfg.Middlewares.Headers.CustomRequestHeaders != nil { + for k, v := range s.cfg.Middlewares.Headers.CustomRequestHeaders { + r.Header.Add(k, v) + } + } + + if s.cfg.Middlewares.Headers.CustomResponseHeaders != nil { + for k, v := range s.cfg.Middlewares.Headers.CustomResponseHeaders { + w.Header().Set(k, v) + } + } + + f(w, r) + } +} + +func (s *Service) initMiddlewares() error { + if s.cfg.Middlewares.EnableHeaders() { + s.AddMiddleware(s.headersMiddleware) + } + + return nil +} |