Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
0ed29d09
Commit
0ed29d09
authored
Apr 22, 2018
by
James Edwards-Jones
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Show error on failed OAuth account link
parent
5ede4e78
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
46 additions
and
4 deletions
+46
-4
app/controllers/omniauth_callbacks_controller.rb
app/controllers/omniauth_callbacks_controller.rb
+6
-0
lib/gitlab/auth/o_auth/identity_linker.rb
lib/gitlab/auth/o_auth/identity_linker.rb
+16
-4
lib/gitlab/auth/omniauth_identity_linker_base.rb
lib/gitlab/auth/omniauth_identity_linker_base.rb
+4
-0
spec/lib/gitlab/auth/o_auth/identity_linker_spec.rb
spec/lib/gitlab/auth/o_auth/identity_linker_spec.rb
+20
-0
No files found.
app/controllers/omniauth_callbacks_controller.rb
View file @
0ed29d09
...
...
@@ -95,6 +95,8 @@ class OmniauthCallbacksController < Devise::OmniauthCallbacksController
if
identity_linker
.
created?
redirect_identity_linked
elsif
identity_linker
.
error_message
.
present?
redirect_identity_link_failed
(
identity_linker
.
error_message
)
else
redirect_identity_exists
end
...
...
@@ -107,6 +109,10 @@ class OmniauthCallbacksController < Devise::OmniauthCallbacksController
redirect_to
after_sign_in_path_for
(
current_user
)
end
def
redirect_identity_link_failed
(
error_message
)
redirect_to
profile_account_path
,
notice:
"Authentication failed:
#{
error_message
}
"
end
def
redirect_identity_linked
redirect_to
profile_account_path
,
notice:
'Authentication method updated'
end
...
...
lib/gitlab/auth/o_auth/identity_linker.rb
View file @
0ed29d09
...
...
@@ -3,11 +3,23 @@ module Gitlab
module
OAuth
class
IdentityLinker
<
OmniauthIdentityLinkerBase
def
create_or_update
current_user
.
identities
.
with_extern_uid
(
oauth
[
'provider'
],
oauth
[
'uid'
])
.
first_or_create
(
extern_uid:
oauth
[
'uid'
])
if
identity
.
new_record?
@created
=
identity
.
save
end
end
def
error_message
identity
.
validate
identity
.
errors
.
full_messages
.
join
(
', '
)
end
private
@created
=
true
def
identity
@identity
||=
current_user
.
identities
.
with_extern_uid
(
oauth
[
'provider'
],
oauth
[
'uid'
])
.
first_or_initialize
(
extern_uid:
oauth
[
'uid'
])
end
end
end
...
...
lib/gitlab/auth/omniauth_identity_linker_base.rb
View file @
0ed29d09
...
...
@@ -13,6 +13,10 @@ module Gitlab
@created
end
def
error_message
''
end
def
create_or_update
raise
NotImplementedError
end
...
...
spec/lib/gitlab/auth/o_auth/identity_linker_spec.rb
View file @
0ed29d09
...
...
@@ -14,6 +14,26 @@ describe Gitlab::Auth::OAuth::IdentityLinker do
it
"doesn't create new identity"
do
expect
{
subject
.
create_or_update
}.
not_to
change
{
Identity
.
count
}
end
it
"#created? returns false"
do
subject
.
create_or_update
expect
(
subject
).
not_to
be_created
end
end
context
'identity already linked to different user'
do
let!
(
:identity
)
{
create
(
:identity
,
provider:
provider
,
extern_uid:
uid
)
}
it
"#created? returns false"
do
subject
.
create_or_update
expect
(
subject
).
not_to
be_created
end
it
'exposes error message'
do
expect
(
subject
.
error_message
).
to
eq
'Extern uid has already been taken'
end
end
context
'identity needs to be created'
do
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment