2018-02-05 16:05:59 -05:00
|
|
|
package middleware // import "github.com/docker/docker/api/server/middleware"
|
2016-02-24 13:17:43 -05:00
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
|
2017-07-26 17:42:13 -04:00
|
|
|
"github.com/sirupsen/logrus"
|
2016-02-24 13:17:43 -05:00
|
|
|
"golang.org/x/net/context"
|
|
|
|
)
|
|
|
|
|
2016-04-08 19:22:39 -04:00
|
|
|
// CORSMiddleware injects CORS headers to each request
|
|
|
|
// when it's configured.
|
|
|
|
type CORSMiddleware struct {
|
|
|
|
defaultHeaders string
|
|
|
|
}
|
2016-02-24 13:17:43 -05:00
|
|
|
|
2016-04-08 19:22:39 -04:00
|
|
|
// NewCORSMiddleware creates a new CORSMiddleware with default headers.
|
|
|
|
func NewCORSMiddleware(d string) CORSMiddleware {
|
|
|
|
return CORSMiddleware{defaultHeaders: d}
|
2016-02-24 13:17:43 -05:00
|
|
|
}
|
|
|
|
|
2016-04-08 19:22:39 -04:00
|
|
|
// WrapHandler returns a new handler function wrapping the previous one in the request chain.
|
|
|
|
func (c CORSMiddleware) WrapHandler(handler func(ctx context.Context, w http.ResponseWriter, r *http.Request, vars map[string]string) error) func(ctx context.Context, w http.ResponseWriter, r *http.Request, vars map[string]string) error {
|
|
|
|
return func(ctx context.Context, w http.ResponseWriter, r *http.Request, vars map[string]string) error {
|
|
|
|
// If "api-cors-header" is not given, but "api-enable-cors" is true, we set cors to "*"
|
|
|
|
// otherwise, all head values will be passed to HTTP handler
|
|
|
|
corsHeaders := c.defaultHeaders
|
|
|
|
if corsHeaders == "" {
|
|
|
|
corsHeaders = "*"
|
|
|
|
}
|
|
|
|
|
|
|
|
logrus.Debugf("CORS header is enabled and set to: %s", corsHeaders)
|
|
|
|
w.Header().Add("Access-Control-Allow-Origin", corsHeaders)
|
|
|
|
w.Header().Add("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, X-Registry-Auth")
|
|
|
|
w.Header().Add("Access-Control-Allow-Methods", "HEAD, GET, POST, DELETE, PUT, OPTIONS")
|
|
|
|
return handler(ctx, w, r, vars)
|
|
|
|
}
|
2016-02-24 13:17:43 -05:00
|
|
|
}
|