To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.

Statistics Download as Zip
| Branch: | Tag: | Revision:

root / .svn / pristine / d5 / d562875108cecc41042a4d0be1488884f1e06a95.svn-base @ 1297:0a574315af3e

History | View | Annotate | Download (1.96 KB)

1
# Redmine - project management software
2
# Copyright (C) 2006-2011  Jean-Philippe Lang
3
#
4
# This program is free software; you can redistribute it and/or
5
# modify it under the terms of the GNU General Public License
6
# as published by the Free Software Foundation; either version 2
7
# of the License, or (at your option) any later version.
8
#
9
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
# GNU General Public License for more details.
13
#
14
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17

    
18
class AuthSource < ActiveRecord::Base
19
  include Redmine::Ciphering
20

    
21
  has_many :users
22

    
23
  validates_presence_of :name
24
  validates_uniqueness_of :name
25
  validates_length_of :name, :maximum => 60
26

    
27
  def authenticate(login, password)
28
  end
29

    
30
  def test_connection
31
  end
32

    
33
  def auth_method_name
34
    "Abstract"
35
  end
36

    
37
  def account_password
38
    read_ciphered_attribute(:account_password)
39
  end
40

    
41
  def account_password=(arg)
42
    write_ciphered_attribute(:account_password, arg)
43
  end
44

    
45
  def allow_password_changes?
46
    self.class.allow_password_changes?
47
  end
48

    
49
  # Does this auth source backend allow password changes?
50
  def self.allow_password_changes?
51
    false
52
  end
53

    
54
  # Try to authenticate a user not yet registered against available sources
55
  def self.authenticate(login, password)
56
    AuthSource.find(:all, :conditions => ["onthefly_register=?", true]).each do |source|
57
      begin
58
        logger.debug "Authenticating '#{login}' against '#{source.name}'" if logger && logger.debug?
59
        attrs = source.authenticate(login, password)
60
      rescue => e
61
        logger.error "Error during authentication: #{e.message}"
62
        attrs = nil
63
      end
64
      return attrs if attrs
65
    end
66
    return nil
67
  end
68
end