PageRenderTime 25ms CodeModel.GetById 18ms RepoModel.GetById 0ms app.codeStats 0ms

/app/helpers/auth_helper.rb

https://gitlab.com/sbeleidy/gitlab-ee
Ruby | 74 lines | 57 code | 17 blank | 0 comment | 1 complexity | 886f62d5af2ee298677483c291ad206c MD5 | raw file
  1. module AuthHelper
  2. PROVIDERS_WITH_ICONS = %w(twitter github gitlab bitbucket google_oauth2 facebook azure_oauth2).freeze
  3. FORM_BASED_PROVIDERS = [/\Aldap/, 'kerberos', 'crowd'].freeze
  4. def ldap_enabled?
  5. Gitlab.config.ldap.enabled
  6. end
  7. def kerberos_enabled?
  8. auth_providers.include?(:kerberos)
  9. end
  10. def omniauth_enabled?
  11. Gitlab.config.omniauth.enabled
  12. end
  13. def provider_has_icon?(name)
  14. PROVIDERS_WITH_ICONS.include?(name.to_s)
  15. end
  16. def auth_providers
  17. Gitlab::OAuth::Provider.providers
  18. end
  19. def label_for_provider(name)
  20. Gitlab::OAuth::Provider.label_for(name)
  21. end
  22. def form_based_provider?(name)
  23. FORM_BASED_PROVIDERS.any? { |pattern| pattern === name.to_s }
  24. end
  25. def form_based_providers
  26. auth_providers.select { |provider| form_based_provider?(provider) }
  27. end
  28. def crowd_enabled?
  29. auth_providers.include? :crowd
  30. end
  31. def button_based_providers
  32. auth_providers.reject { |provider| form_based_provider?(provider) }
  33. end
  34. def provider_image_tag(provider, size = 64)
  35. label = label_for_provider(provider)
  36. if provider_has_icon?(provider)
  37. file_name = "#{provider.to_s.split('_').first}_#{size}.png"
  38. image_tag("auth_buttons/#{file_name}", alt: label, title: "Sign in with #{label}")
  39. else
  40. label
  41. end
  42. end
  43. def auth_active?(provider)
  44. current_user.identities.exists?(provider: provider.to_s)
  45. end
  46. def two_factor_skippable?
  47. current_application_settings.require_two_factor_authentication &&
  48. !current_user.two_factor_enabled &&
  49. current_application_settings.two_factor_grace_period &&
  50. !two_factor_grace_period_expired?
  51. end
  52. def two_factor_grace_period_expired?
  53. current_user.otp_grace_period_started_at &&
  54. (current_user.otp_grace_period_started_at + current_application_settings.two_factor_grace_period.hours) < Time.current
  55. end
  56. extend self
  57. end