auth_source.rb
73 lines
| 2.1 KiB
| text/x-ruby
|
RubyLexer
|
r6721 | # Redmine - project management software | ||
# Copyright (C) 2006-2011 Jean-Philippe Lang | ||||
|
r10 | # | ||
# This program is free software; you can redistribute it and/or | ||||
# modify it under the terms of the GNU General Public License | ||||
# as published by the Free Software Foundation; either version 2 | ||||
# of the License, or (at your option) any later version. | ||||
|
r6721 | # | ||
|
r10 | # This program is distributed in the hope that it will be useful, | ||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
# GNU General Public License for more details. | ||||
|
r6721 | # | ||
|
r10 | # You should have received a copy of the GNU General Public License | ||
# along with this program; if not, write to the Free Software | ||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | ||||
|
r8791 | # Generic exception for when the AuthSource can not be reached | ||
# (eg. can not connect to the LDAP) | ||||
class AuthSourceException < Exception; end | ||||
|
r10 | class AuthSource < ActiveRecord::Base | ||
|
r9112 | include Redmine::SubclassFactory | ||
|
r4830 | include Redmine::Ciphering | ||
|
r6721 | |||
|
r10 | has_many :users | ||
|
r6721 | |||
|
r10 | validates_presence_of :name | ||
validates_uniqueness_of :name | ||||
|
r1661 | validates_length_of :name, :maximum => 60 | ||
|
r10 | |||
def authenticate(login, password) | ||||
end | ||||
|
r6721 | |||
|
r10 | def test_connection | ||
end | ||||
|
r6721 | |||
|
r10 | def auth_method_name | ||
"Abstract" | ||||
end | ||||
|
r6721 | |||
|
r4830 | def account_password | ||
read_ciphered_attribute(:account_password) | ||||
end | ||||
|
r6721 | |||
|
r4830 | def account_password=(arg) | ||
write_ciphered_attribute(:account_password, arg) | ||||
end | ||||
|
r10 | |||
|
r3631 | def allow_password_changes? | ||
self.class.allow_password_changes? | ||||
end | ||||
# Does this auth source backend allow password changes? | ||||
def self.allow_password_changes? | ||||
false | ||||
end | ||||
|
r10 | # Try to authenticate a user not yet registered against available sources | ||
def self.authenticate(login, password) | ||||
AuthSource.find(:all, :conditions => ["onthefly_register=?", true]).each do |source| | ||||
begin | ||||
logger.debug "Authenticating '#{login}' against '#{source.name}'" if logger && logger.debug? | ||||
attrs = source.authenticate(login, password) | ||||
|
r2054 | rescue => e | ||
logger.error "Error during authentication: #{e.message}" | ||||
|
r10 | attrs = nil | ||
end | ||||
return attrs if attrs | ||||
end | ||||
return nil | ||||
end | ||||
end | ||||