summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2012-10-21 09:13:35 -0700
committerDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2012-10-21 09:13:35 -0700
commitfb903de50828ca01c533e5f02527623ff27a253b (patch)
tree97ed2a7376558e613710566e1eaf611ec3e452ca
parent4e363c613680230dc8f84169f4ad9c348c9f2826 (diff)
parent054c15e7b5f9967417a0ea03aad0c4d77afd3bca (diff)
downloadgitlab-ce-fb903de50828ca01c533e5f02527623ff27a253b.tar.gz
Merge pull request #1740 from godric7/master
Enable Oauth login for existing regular users
-rw-r--r--lib/gitlab/auth.rb4
1 files changed, 4 insertions, 0 deletions
diff --git a/lib/gitlab/auth.rb b/lib/gitlab/auth.rb
index 500cb64df48..5a24c5d01b5 100644
--- a/lib/gitlab/auth.rb
+++ b/lib/gitlab/auth.rb
@@ -48,9 +48,13 @@ module Gitlab
def find_or_new_for_omniauth(auth)
provider, uid = auth.provider, auth.uid
+ email = auth.info.email.downcase unless auth.info.email.nil?
if @user = User.find_by_provider_and_extern_uid(provider, uid)
@user
+ elsif @user = User.find_by_email(email)
+ @user.update_attributes(:extern_uid => uid, :provider => provider)
+ @user
else
if Gitlab.config.omniauth['allow_single_sign_on']
@user = create_from_omniauth(auth)