Module: HolmanActiveDirectory

Defined in:
lib/holman_active_directory.rb,
lib/holman_active_directory/filter.rb,
lib/holman_active_directory/version.rb,
lib/holman_active_directory/directory.rb,
lib/holman_active_directory/access_control.rb

Defined Under Namespace

Classes: AccessControl, Directory, Filter, NoDirectory

Constant Summary collapse

VERSION =
"2.1.0"

Class Attribute Summary collapse

Class Method Summary collapse

Class Attribute Details

.directoriesObject (readonly)

Returns the value of attribute directories.



104
105
106
# File 'lib/holman_active_directory.rb', line 104

def directories
  @directories
end

Class Method Details

.active_account?(dn) ⇒ Boolean

Returns:

  • (Boolean)


30
31
32
# File 'lib/holman_active_directory.rb', line 30

def active_account?(dn)
  directory(dn).active_account?(dn)
end

.directory(dn) ⇒ Object

Raises:



50
51
52
53
54
# File 'lib/holman_active_directory.rb', line 50

def directory(dn)
  d = directories.find { |directory| dn.end_with? directory.base }
  raise NoDirectory, "no directory for dn: #{dn}" unless d
  d
end

.initialize_directoriesObject



65
66
67
# File 'lib/holman_active_directory.rb', line 65

def initialize_directories
  @directories = server_configs.map { |name, attrs| Directory.new(name, Filter.send(attrs[:filter])) }
end

.peach_directory(options) ⇒ Object



56
57
58
# File 'lib/holman_active_directory.rb', line 56

def peach_directory(options)
  options.fetch(:directories) { directories }.flat_pmap { |directory| yield directory }.compact
end

.search_all_directories(options) ⇒ Object



13
14
15
# File 'lib/holman_active_directory.rb', line 13

def search_all_directories(options)
  peach_directory(options) { |directory| directory.search(options) }
end

.search_all_directories_for_employee_id(employee_id, options = {}) ⇒ Object



17
18
19
# File 'lib/holman_active_directory.rb', line 17

def search_all_directories_for_employee_id(employee_id, options={})
  peach_directory(options) { |directory| directory.search_for_employee_id(employee_id, options) }
end

.search_all_directories_for_username(username, options = {}) ⇒ Object



21
22
23
# File 'lib/holman_active_directory.rb', line 21

def search_all_directories_for_username(username, options={})
  peach_directory(options) { |directory| directory.search_for_username(username, options) }
end

.server_configsObject



69
70
71
# File 'lib/holman_active_directory.rb', line 69

def server_configs
  @server_configs || {}
end

.server_configs=(hash) ⇒ Object



60
61
62
63
# File 'lib/holman_active_directory.rb', line 60

def server_configs=(hash)
  @server_configs = hash
  initialize_directories
end

.set_fastest_hosts(ping_count = 5) ⇒ Object



73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
# File 'lib/holman_active_directory.rb', line 73

def set_fastest_hosts(ping_count=5)
  require 'net/ping/tcp'

  domain = Struct.new(:directory, :addresses) do
    def fastest_address
      addresses.sort_by(&:avg).first
    end
  end

  address = Struct.new(:ip, :avg)

  domains = directories.map { |d| domain.new(d) }

  domains.each do |d|
    d.addresses = Resolv::DNS.new.getaddresses(d.directory.config[:host]).map { |ip| address.new(ip.to_s) }
  end

  domains.each do |d|
    d.addresses.each do |a|
      pings = ping_count.times.map { Net::Ping::TCP.new(a.ip, 'ldap', 0.05).ping || 60 }
      a.avg = pings.inject(0, &:+) / ping_count
    end
  end

  domains.each do |d|
    d.directory.config[:host] = d.fastest_address.ip
  end

  domains
end

.sso_connection(dn) ⇒ Object



34
35
36
# File 'lib/holman_active_directory.rb', line 34

def sso_connection(dn)
  directory(dn).sso_connection
end

.sso_connection_for_dn(dn) ⇒ Object



46
47
48
# File 'lib/holman_active_directory.rb', line 46

def sso_connection_for_dn(dn)
  directory(dn).sso_connection
end

.test_all_directoriesObject



106
107
108
109
110
111
112
113
114
115
116
# File 'lib/holman_active_directory.rb', line 106

def test_all_directories
  directories.map do |directory|
    [
        directory.name,
        directory.test_bind,
        directory.test_search_for_employee_id,
        directory.test_search_for_username,
        directory.test_active_account?,
    ]
  end
end

.update(dn, operations) ⇒ Object



38
39
40
# File 'lib/holman_active_directory.rb', line 38

def update(dn, operations)
  directory(dn).update(dn, operations)
end

.upload_photo(dn, photo) ⇒ Object



42
43
44
# File 'lib/holman_active_directory.rb', line 42

def upload_photo(dn, photo)
  directory(dn).update(dn, [[:replace, :thumbnailPhoto, photo]])
end

.valid_password?(dn, password) ⇒ Boolean

Returns:

  • (Boolean)


25
26
27
28
# File 'lib/holman_active_directory.rb', line 25

def valid_password?(dn, password)
  return false unless password.present?
  directory(dn).valid_password?(dn, password)
end