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
6999f717
Commit
6999f717
authored
Jun 01, 2018
by
Lin Jen-Shin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Introduce Gitlab::Auth.omniauth_setup_providers
Which could extend from EE
parent
d46e0a3b
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
39 additions
and
6 deletions
+39
-6
config/initializers/omniauth.rb
config/initializers/omniauth.rb
+1
-6
ee/lib/ee/gitlab/auth.rb
ee/lib/ee/gitlab/auth.rb
+19
-0
lib/gitlab/auth.rb
lib/gitlab/auth.rb
+19
-0
No files found.
config/initializers/omniauth.rb
View file @
6999f717
...
@@ -19,10 +19,5 @@ end
...
@@ -19,10 +19,5 @@ end
if
Gitlab
.
config
.
omniauth
.
enabled
if
Gitlab
.
config
.
omniauth
.
enabled
provider_names
=
Gitlab
.
config
.
omniauth
.
providers
.
map
(
&
:name
)
provider_names
=
Gitlab
.
config
.
omniauth
.
providers
.
map
(
&
:name
)
require
'omniauth-kerberos'
if
provider_names
.
include?
(
'kerberos'
)
Gitlab
::
Auth
.
omniauth_setup_providers
(
provider_names
)
require_dependency
'omni_auth/strategies/kerberos_spnego'
if
provider_names
.
include?
(
'kerberos_spnego'
)
if
provider_names
.
include?
(
'group_saml'
)
OmniAuth
.
config
.
on_failure
=
::
Gitlab
::
Auth
::
GroupSaml
::
FailureHandler
.
new
(
OmniAuth
.
config
.
on_failure
)
end
end
end
ee/lib/ee/gitlab/auth.rb
View file @
6999f717
module
EE
module
EE
module
Gitlab
module
Gitlab
module
Auth
module
Auth
extend
::
Gitlab
::
Utils
::
Override
override
:omniauth_customized_providers
def
omniauth_customized_providers
@omniauth_customized_providers
||=
super
.
concat
(
%w[kerberos_spnego group_saml]
)
end
override
:omniauth_setup_a_provider
def
omniauth_setup_a_provider
(
provider
)
super
if
provider
==
'group_saml'
OmniAuth
.
config
.
on_failure
=
::
Gitlab
::
Auth
::
GroupSaml
::
FailureHandler
.
new
(
OmniAuth
.
config
.
on_failure
)
end
end
def
find_with_user_password
(
login
,
password
)
def
find_with_user_password
(
login
,
password
)
if
Devise
.
omniauth_providers
.
include?
(
:kerberos
)
if
Devise
.
omniauth_providers
.
include?
(
:kerberos
)
kerberos_user
=
::
Gitlab
::
Kerberos
::
Authentication
.
login
(
login
,
password
)
kerberos_user
=
::
Gitlab
::
Kerberos
::
Authentication
.
login
(
login
,
password
)
...
...
lib/gitlab/auth.rb
View file @
6999f717
...
@@ -16,6 +16,25 @@ module Gitlab
...
@@ -16,6 +16,25 @@ module Gitlab
class
<<
self
class
<<
self
prepend
EE
::
Gitlab
::
Auth
prepend
EE
::
Gitlab
::
Auth
def
omniauth_customized_providers
@omniauth_customized_providers
||=
%w[bitbucket jwt]
end
def
omniauth_setup_providers
(
provider_names
)
provider_names
.
each
do
|
provider
|
omniauth_setup_a_provider
(
provider
)
end
end
def
omniauth_setup_a_provider
(
provider
)
case
provider
when
'kerberos'
require
'omniauth-kerberos'
when
*
omniauth_customized_providers
require_dependency
"omni_auth/strategies/
#{
provider
}
"
end
end
def
find_for_git_client
(
login
,
password
,
project
:,
ip
:)
def
find_for_git_client
(
login
,
password
,
project
:,
ip
:)
raise
"Must provide an IP for rate limiting"
if
ip
.
nil?
raise
"Must provide an IP for rate limiting"
if
ip
.
nil?
...
...
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