mirror of
https://github.com/grafana/grafana.git
synced 2025-01-09 23:53:25 -06:00
OAuth: Fix parsing of ID token if header contains non-string value (#44159)
Fixes #41111
This commit is contained in:
parent
3c1122cf29
commit
9ab9fd802b
@ -231,13 +231,19 @@ func (s *SocialGenericOAuth) extractFromToken(token *oauth2.Token) *UserInfoJson
|
||||
return nil
|
||||
}
|
||||
|
||||
var header map[string]string
|
||||
var header map[string]interface{}
|
||||
if err := json.Unmarshal(headerBytes, &header); err != nil {
|
||||
s.log.Error("Error deserializing header", "error", err)
|
||||
return nil
|
||||
}
|
||||
|
||||
if compression, ok := header["zip"]; ok {
|
||||
if compressionVal, exists := header["zip"]; exists {
|
||||
compression, ok := compressionVal.(string)
|
||||
if !ok {
|
||||
s.log.Warn("Unknown compression algorithm")
|
||||
return nil
|
||||
}
|
||||
|
||||
if compression != "DEF" {
|
||||
s.log.Warn("Unknown compression algorithm", "algorithm", compression)
|
||||
return nil
|
||||
|
@ -727,6 +727,14 @@ func TestPayloadCompression(t *testing.T) {
|
||||
},
|
||||
ExpectedEmail: "john.doe@example.com",
|
||||
},
|
||||
{
|
||||
Name: "Given a valid DEFLATE compressed id_token with numeric header, return userInfo",
|
||||
OAuth2Extra: map[string]interface{}{
|
||||
// Generated from https://token.dev/
|
||||
"id_token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiIsInZlciI6NH0.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiYWRtaW4iOnRydWUsImlhdCI6MTY0MjUxNjYwNSwiZXhwIjoxNjQyNTIwMjA1LCJlbWFpbCI6ImpvaG4uZG9lQGV4YW1wbGUuY29tIn0.ANndoPWIHNjKPG8na7UUq7nan1RgF8-ze8STU31RXcA",
|
||||
},
|
||||
ExpectedEmail: "john.doe@example.com",
|
||||
},
|
||||
{
|
||||
Name: "Given an invalid DEFLATE compressed id_token, return nil",
|
||||
OAuth2Extra: map[string]interface{}{
|
||||
|
Loading…
Reference in New Issue
Block a user