gem 'devise', '~> 4.4'
gem 'devise-two-factor', '~> 3.0'
-gem 'devise_pam_authenticatable2', '~> 8.0', install_if: -> { ENV['PAM_ENABLED'] == 'true' }
+group :pam_authentication, optional: true do
+ gem 'devise_pam_authenticatable2', '~> 9.0'
+end
gem 'net-ldap', '~> 0.10'
gem 'omniauth-cas', '~> 1.1'
gem 'omniauth-saml', '~> 1.10'
devise (~> 4.0)
railties (< 5.2)
rotp (~> 2.0)
- devise_pam_authenticatable2 (8.0.1)
+ devise_pam_authenticatable2 (9.0.0)
devise (>= 4.0.0)
rpam2 (~> 3.0)
diff-lcs (1.3)
climate_control (~> 0.2)
devise (~> 4.4)
devise-two-factor (~> 3.0)
- devise_pam_authenticatable2 (~> 8.0)
+ devise_pam_authenticatable2 (~> 9.0)
doorkeeper (~> 4.2)
dotenv-rails (~> 2.2)
fabrication (~> 2.18)
devise :registerable, :recoverable, :rememberable, :trackable, :validatable,
:confirmable
+ devise :pam_authenticatable if ENV['PAM_ENABLED'] == 'true'
+
devise :omniauthable
belongs_to :account, inverse_of: :user
def pam_conflict?
return false unless Devise.pam_authentication
- encrypted_password.present? && is_pam_account?
+ encrypted_password.present? && pam_managed_user?
end
def pam_get_name
end
def self.pam_get_user(attributes = {})
- if attributes[:email]
- resource =
- if Devise.check_at_sign && !attributes[:email].index('@')
- joins(:account).find_by(accounts: { username: attributes[:email] })
- else
- find_by(email: attributes[:email])
- end
-
- if resource.blank?
- resource = new(email: attributes[:email])
- if Devise.check_at_sign && !resource[:email].index('@')
- resource[:email] = "#{attributes[:email]}@#{resource.find_pam_suffix}"
- end
+ return nil unless attributes[:email]
+ resource =
+ if Devise.check_at_sign && !attributes[:email].index('@')
+ joins(:account).find_by(accounts: { username: attributes[:email] })
+ else
+ find_by(email: attributes[:email])
+ end
+
+ if resource.blank?
+ resource = new(email: attributes[:email])
+ if Devise.check_at_sign && !resource[:email].index('@')
+ resource[:email] = Rpam2.getenv(resource.find_pam_service, attributes[:email], attributes[:password], 'email', false)
+ resource[:email] = "#{attributes[:email]}@#{resource.find_pam_suffix}" unless resource[:email]
end
- resource
end
+ resource
end
def self.ldap_get_user(attributes = {})