fix: allow Authorization header when doing CORS
The Authorization header needs to be allowed when doing CORS because otherwise /userinfo can't work. It isn't one of the headers explicitly allowed by default by Gorilla, so we have to call handlers.AllowedHeaders() to specify it. Issues: #1532 Signed-off-by: Alastair Houghton <alastair@alastairs-place.net>
This commit is contained in:
parent
828a1c6ec2
commit
9187aa669d
1 changed files with 8 additions and 2 deletions
|
@ -294,8 +294,14 @@ func newServer(ctx context.Context, c Config, rotationStrategy rotationStrategy)
|
||||||
handleWithCORS := func(p string, h http.HandlerFunc) {
|
handleWithCORS := func(p string, h http.HandlerFunc) {
|
||||||
var handler http.Handler = h
|
var handler http.Handler = h
|
||||||
if len(c.AllowedOrigins) > 0 {
|
if len(c.AllowedOrigins) > 0 {
|
||||||
corsOption := handlers.AllowedOrigins(c.AllowedOrigins)
|
allowedHeaders := []string{
|
||||||
handler = handlers.CORS(corsOption)(handler)
|
"Authorization",
|
||||||
|
}
|
||||||
|
cors := handlers.CORS(
|
||||||
|
handlers.AllowedOrigins(c.AllowedOrigins),
|
||||||
|
handlers.AllowedHeaders(allowedHeaders),
|
||||||
|
)
|
||||||
|
handler = cors(handler)
|
||||||
}
|
}
|
||||||
r.Handle(path.Join(issuerURL.Path, p), instrumentHandlerCounter(p, handler))
|
r.Handle(path.Join(issuerURL.Path, p), instrumentHandlerCounter(p, handler))
|
||||||
}
|
}
|
||||||
|
|
Reference in a new issue