Display multiple LDAP servers on login page

parent 8772c2a1
...@@ -30,6 +30,13 @@ class OmniauthCallbacksController < Devise::OmniauthCallbacksController ...@@ -30,6 +30,13 @@ class OmniauthCallbacksController < Devise::OmniauthCallbacksController
end end
end end
alias_method :ldap0, :ldap
alias_method :ldap1, :ldap
alias_method :ldap2, :ldap
alias_method :ldap3, :ldap
alias_method :ldap4, :ldap
alias_method :ldap5, :ldap
def omniauth_error def omniauth_error
@provider = params[:provider] @provider = params[:provider]
@error = params[:error] @error = params[:error]
......
...@@ -18,6 +18,10 @@ class SessionsController < Devise::SessionsController ...@@ -18,6 +18,10 @@ class SessionsController < Devise::SessionsController
store_location_for(:redirect, redirect_path) store_location_for(:redirect, redirect_path)
end end
if Gitlab.config.ldap.enabled
@ldap_servers = Gitlab.config.ldap.servers
end
super super
end end
......
...@@ -244,10 +244,6 @@ module ApplicationHelper ...@@ -244,10 +244,6 @@ module ApplicationHelper
end end
end end
def ldap_enabled?
Gitlab.config.ldap.enabled
end
def link_to(name = nil, options = nil, html_options = nil, &block) def link_to(name = nil, options = nil, html_options = nil, &block)
begin begin
uri = URI(options) uri = URI(options)
......
module OauthHelper module OauthHelper
def ldap_enabled? def ldap_enabled?
Devise.omniauth_providers.include?(:ldap) Gitlab.config.ldap.enabled
end end
def default_providers def default_providers
......
= form_tag(user_omniauth_callback_path(:ldap), id: 'new_ldap_user' ) do = form_tag(user_omniauth_callback_path(provider), id: 'new_ldap_user' ) do
= text_field_tag :username, nil, {class: "form-control top", placeholder: "LDAP Login", autofocus: "autofocus"} = text_field_tag :username, nil, {class: "form-control top", placeholder: "LDAP Login", autofocus: "autofocus"}
= password_field_tag :password, nil, {class: "form-control bottom", placeholder: "Password"} = password_field_tag :password, nil, {class: "form-control bottom", placeholder: "Password"}
%br/ %br/
......
...@@ -4,20 +4,22 @@ ...@@ -4,20 +4,22 @@
.panel-body .panel-body
- if ldap_enabled? && gitlab_config.signin_enabled - if ldap_enabled? && gitlab_config.signin_enabled
%ul.nav.nav-tabs %ul.nav.nav-tabs
%li.active - @ldap_servers.each_with_index do |server, i|
= link_to 'LDAP', '#tab-ldap', 'data-toggle' => 'tab' %li{class: (:active if server['primary'])}
= link_to server['name'], "#tab-ldap#{i}", 'data-toggle' => 'tab'
%li %li
= link_to 'Standard', '#tab-signin', 'data-toggle' => 'tab' = link_to 'Standard', '#tab-signin', 'data-toggle' => 'tab'
.tab-content .tab-content
%div#tab-ldap.tab-pane.active - @ldap_servers.each_with_index do |server, i|
= render partial: 'devise/sessions/new_ldap' %div.tab-pane{id: "tab-ldap#{i}", class: (:active if server['primary'])}
= render 'devise/sessions/new_ldap', provider: "ldap#{i}"
%div#tab-signin.tab-pane %div#tab-signin.tab-pane
= render partial: 'devise/sessions/new_base' = render 'devise/sessions/new_base'
- elsif ldap_enabled? - elsif ldap_enabled?
= render partial: 'devise/sessions/new_ldap' = render 'devise/sessions/new_ldap', ldap_servers: @ldap_servers
- elsif gitlab_config.signin_enabled - elsif gitlab_config.signin_enabled
= render partial: 'devise/sessions/new_base' = render 'devise/sessions/new_base'
- else - else
%div %div
No authentication methods configured. No authentication methods configured.
......
...@@ -5,4 +5,4 @@ module OmniAuth::Strategies ...@@ -5,4 +5,4 @@ module OmniAuth::Strategies
class Ldap3 < LDAP; end class Ldap3 < LDAP; end
class Ldap4 < LDAP; end class Ldap4 < LDAP; end
class Ldap5 < LDAP; end class Ldap5 < LDAP; end
end end
\ No newline at end of file
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