Commit ac518139 authored by Eric Chiang's avatar Eric Chiang Committed by GitHub

Merge pull request #537 from wyattanderson/register-display-name

server: when registering a user, set user name if OIDC identity contains one
parents 5dec7194 26508c6b
...@@ -416,6 +416,13 @@ func (s *Server) Login(ident oidc.Identity, key string) (string, error) { ...@@ -416,6 +416,13 @@ func (s *Server) Login(ident oidc.Identity, key string) (string, error) {
if err != nil { if err != nil {
return "", fmt.Errorf("getting created user: %v", err) return "", fmt.Errorf("getting created user: %v", err)
} }
if ses.Identity.Name != "" && ses.Identity.Name != usr.DisplayName {
err = s.UserManager.SetDisplayName(usr, ses.Identity.Name)
if err != nil {
return "", fmt.Errorf("couldn't set display name for user: %v", err)
}
}
} else if err != nil { } else if err != nil {
return "", fmt.Errorf("getting user: %v", err) return "", fmt.Errorf("getting user: %v", err)
} }
......
...@@ -358,6 +358,42 @@ func TestServerLoginDisabledUser(t *testing.T) { ...@@ -358,6 +358,42 @@ func TestServerLoginDisabledUser(t *testing.T) {
} }
} }
func TestServerLoginDisplayName(t *testing.T) {
f, err := makeTestFixtures()
if err != nil {
t.Fatalf("error making test fixtures: %v", err)
}
sm := f.sessionManager
sessionID, err := sm.NewSession(testConnectorIDOpenID, testClientID, "bogus", testRedirectURL, "", false, []string{"openid"})
if err != nil {
t.Fatalf("Unexpected error: %v", err)
}
key, err := sm.NewSessionKey(sessionID)
if err != nil {
t.Errorf("new session key: %v", err)
}
f.srv.RegisterOnFirstLogin = true
ident := oidc.Identity{ID: testUserRemoteID1, Name: "elroy", Email: "elroy@example.com"}
_, err = f.srv.Login(ident, key)
if err != nil {
t.Fatalf("Unexpected error: %v", err)
}
usr, err := f.srv.UserRepo.GetByEmail(nil, ident.Email)
if err != nil {
t.Fatalf("Couldn't retrieve user we just created: %v", err)
}
if usr.DisplayName != ident.Name {
t.Fatalf("User display name (%s) did not match name on identity (%s)",
usr.DisplayName, ident.Name)
}
}
func TestServerCodeToken(t *testing.T) { func TestServerCodeToken(t *testing.T) {
f, err := makeTestFixtures() f, err := makeTestFixtures()
if err != nil { if err != nil {
......
...@@ -120,6 +120,25 @@ func (m *UserManager) Disable(userID string, disabled bool) error { ...@@ -120,6 +120,25 @@ func (m *UserManager) Disable(userID string, disabled bool) error {
return nil return nil
} }
func (m *UserManager) SetDisplayName(usr user.User, displayName string) error {
tx, err := m.begin()
if err != nil {
return err
}
defer rollback(tx)
usr.DisplayName = displayName
if err = m.userRepo.Update(tx, usr); err != nil {
return err
}
if err = tx.Commit(); err != nil {
return err
}
return nil
}
// RegisterWithRemoteIdentity creates new user and attaches the given remote identity. // RegisterWithRemoteIdentity creates new user and attaches the given remote identity.
func (m *UserManager) RegisterWithRemoteIdentity(email string, emailVerified bool, rid user.RemoteIdentity) (string, error) { func (m *UserManager) RegisterWithRemoteIdentity(email string, emailVerified bool, rid user.RemoteIdentity) (string, error) {
tx, err := m.begin() tx, err := m.begin()
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment