Skip to content

Commit

Permalink
Make oauth user name and user id configurable
Browse files Browse the repository at this point in the history
Signed-off-by: Josh Winters <[email protected]>
Co-authored-by: Mark Huang <[email protected]>
  • Loading branch information
2 people authored and Rui Yang committed Jan 16, 2020
1 parent 4c790e3 commit 31f3fce
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 10 deletions.
26 changes: 20 additions & 6 deletions connector/oauth/oauth.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,8 @@ type oauthConnector struct {
userInfoURL string
scopes []string
groupsKey string
userIDKey string
userNameKey string
httpClient *http.Client
logger log.Logger
}
Expand All @@ -45,6 +47,8 @@ type Config struct {
UserInfoURL string `json:"userInfoURL"`
Scopes []string `json:"scopes"`
GroupsKey string `json:"groupsKey"`
UserIDKey string `json:"userIDKey"`
UserNameKey string `json:"userNameKey"`
RootCAs []string `json:"rootCAs"`
InsecureSkipVerify bool `json:"insecureSkipVerify"`
}
Expand All @@ -60,6 +64,8 @@ func (c *Config) Open(id string, logger log.Logger) (connector.Connector, error)
userInfoURL: c.UserInfoURL,
scopes: c.Scopes,
groupsKey: c.GroupsKey,
userIDKey: c.UserIDKey,
userNameKey: c.UserNameKey,
redirectURI: c.RedirectURI,
logger: logger,
}
Expand Down Expand Up @@ -165,17 +171,25 @@ func (c *oauthConnector) HandleCallback(s connector.Scopes, r *http.Request) (id
return identity, fmt.Errorf("OAuth Connector: failed to parse userinfo: %v", err)
}

identity.UserID, _ = userInfoResult["user_id"].(string)
if c.userIDKey == "" {
c.userIDKey = "user_id"
}

if c.userNameKey == "" {
c.userNameKey = "user_name"
}

if c.groupsKey == "" {
c.groupsKey = "groups"
}

identity.UserID, _ = userInfoResult[c.userIDKey].(string)
identity.Username, _ = userInfoResult[c.userNameKey].(string)
identity.Name, _ = userInfoResult["name"].(string)
identity.Username, _ = userInfoResult["user_name"].(string)
identity.Email, _ = userInfoResult["email"].(string)
identity.EmailVerified, _ = userInfoResult["email_verified"].(bool)

if s.Groups {
if c.groupsKey == "" {
c.groupsKey = "groups"
}

groups := map[string]bool{}

c.addGroupsFromMap(groups, userInfoResult)
Expand Down
12 changes: 8 additions & 4 deletions connector/oauth/oauth_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -72,8 +72,8 @@ func TestHandleCallBackForGroupsInUserInfo(t *testing.T) {

userInfoClaims := map[string]interface{}{
"name": "test-name",
"user_name": "test-username",
"user_id": "test-user-id",
"user_id_key": "test-user-id",
"user_name_key": "test-username",
"email": "test-email",
"email_verified": true,
"groups_key": []string{"admin-group", "user-group"},
Expand All @@ -93,6 +93,7 @@ func TestHandleCallBackForGroupsInUserInfo(t *testing.T) {
expectEqual(t, identity.Groups[0], "admin-group")
expectEqual(t, identity.Groups[1], "user-group")
expectEqual(t, identity.Name, "test-name")
expectEqual(t, identity.UserID, "test-user-id")
expectEqual(t, identity.Username, "test-username")
expectEqual(t, identity.Email, "test-email")
expectEqual(t, identity.EmailVerified, true)
Expand All @@ -106,8 +107,8 @@ func TestHandleCallBackForGroupsInToken(t *testing.T) {

userInfoClaims := map[string]interface{}{
"name": "test-name",
"user_name": "test-username",
"user_id": "test-user-id",
"user_id_key": "test-user-id",
"user_name_key": "test-username",
"email": "test-email",
"email_verified": true,
}
Expand All @@ -124,6 +125,7 @@ func TestHandleCallBackForGroupsInToken(t *testing.T) {
expectEqual(t, len(identity.Groups), 1)
expectEqual(t, identity.Groups[0], "test-group")
expectEqual(t, identity.Name, "test-name")
expectEqual(t, identity.UserID, "test-user-id")
expectEqual(t, identity.Username, "test-username")
expectEqual(t, identity.Email, "test-email")
expectEqual(t, identity.EmailVerified, true)
Expand Down Expand Up @@ -197,6 +199,8 @@ func newConnector(t *testing.T, serverURL string) *oauthConnector {
UserInfoURL: serverURL + "/userinfo",
Scopes: []string{"openid", "groups"},
GroupsKey: "groups_key",
UserIDKey: "user_id_key",
UserNameKey: "user_name_key",
}

log := logrus.New()
Expand Down

0 comments on commit 31f3fce

Please sign in to comment.