summaryrefslogtreecommitdiff
path: root/service/http
diff options
context:
space:
mode:
authorDmitry Patsura <[email protected]>2019-06-20 13:08:34 +0300
committerDmitry Patsura <[email protected]>2019-06-20 13:08:34 +0300
commitfddaca06c683654cb86934f38681c30188acbbf5 (patch)
tree64b7bfc36f9e49a45473fae33744975b977d26f4 /service/http
parent85126b000d140efdd99573e44241ee1e8b84d3c5 (diff)
Feature(http): Introduce support for customResponseHeaders/customRequestHeaders by headers middleware
Diffstat (limited to 'service/http')
-rw-r--r--service/http/config.go20
-rw-r--r--service/http/service.go31
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
+}