annotate app/models/.svn/text-base/auth_source.rb.svn-base @ 922:ad295b270cd4 live

FIx #446: "non-utf8 paths in repositories blow up repo viewer and reposman" by ensuring the iconv conversion always happens even if source and dest are intended to be the same encoding
author Chris Cannam
date Tue, 13 Mar 2012 16:33:49 +0000
parents 051f544170fe
children
rev   line source
Chris@0 1 # redMine - project management software
Chris@0 2 # Copyright (C) 2006 Jean-Philippe Lang
Chris@0 3 #
Chris@0 4 # This program is free software; you can redistribute it and/or
Chris@0 5 # modify it under the terms of the GNU General Public License
Chris@0 6 # as published by the Free Software Foundation; either version 2
Chris@0 7 # of the License, or (at your option) any later version.
Chris@0 8 #
Chris@0 9 # This program is distributed in the hope that it will be useful,
Chris@0 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
Chris@0 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Chris@0 12 # GNU General Public License for more details.
Chris@0 13 #
Chris@0 14 # You should have received a copy of the GNU General Public License
Chris@0 15 # along with this program; if not, write to the Free Software
Chris@0 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Chris@0 17
Chris@0 18 class AuthSource < ActiveRecord::Base
Chris@245 19 include Redmine::Ciphering
Chris@245 20
Chris@0 21 has_many :users
Chris@0 22
Chris@0 23 validates_presence_of :name
Chris@0 24 validates_uniqueness_of :name
Chris@0 25 validates_length_of :name, :maximum => 60
Chris@0 26
Chris@0 27 def authenticate(login, password)
Chris@0 28 end
Chris@0 29
Chris@0 30 def test_connection
Chris@0 31 end
Chris@0 32
Chris@0 33 def auth_method_name
Chris@0 34 "Abstract"
Chris@0 35 end
Chris@245 36
Chris@245 37 def account_password
Chris@245 38 read_ciphered_attribute(:account_password)
Chris@245 39 end
Chris@245 40
Chris@245 41 def account_password=(arg)
Chris@245 42 write_ciphered_attribute(:account_password, arg)
Chris@245 43 end
Chris@0 44
Chris@0 45 def allow_password_changes?
Chris@0 46 self.class.allow_password_changes?
Chris@0 47 end
Chris@0 48
Chris@0 49 # Does this auth source backend allow password changes?
Chris@0 50 def self.allow_password_changes?
Chris@0 51 false
Chris@0 52 end
Chris@0 53
Chris@0 54 # Try to authenticate a user not yet registered against available sources
Chris@0 55 def self.authenticate(login, password)
Chris@0 56 AuthSource.find(:all, :conditions => ["onthefly_register=?", true]).each do |source|
Chris@0 57 begin
Chris@0 58 logger.debug "Authenticating '#{login}' against '#{source.name}'" if logger && logger.debug?
Chris@0 59 attrs = source.authenticate(login, password)
Chris@0 60 rescue => e
Chris@0 61 logger.error "Error during authentication: #{e.message}"
Chris@0 62 attrs = nil
Chris@0 63 end
Chris@0 64 return attrs if attrs
Chris@0 65 end
Chris@0 66 return nil
Chris@0 67 end
Chris@0 68 end