Class: ActiveLdap::Adapter::NetLdap
- Inherits:
-
Base
- Object
- Base
- ActiveLdap::Adapter::NetLdap
show all
- Defined in:
- lib/active_ldap/adapter/net_ldap.rb
Constant Summary
collapse
- METHOD =
{
:ssl => :simple_tls,
:tls => :start_tls,
:plain => nil,
}
Constants inherited
from Base
Base::VALID_ADAPTER_CONFIGURATION_KEYS
Instance Method Summary
collapse
Methods inherited from Base
#bound?, #connecting?, #disconnect!, #entry_attribute, #initialize, jndi_connection, ldap_connection, #naming_contexts, net_ldap_connection, #rebind, #schema, #supported_control
included
Instance Method Details
#add(dn, entries, options = {}) ⇒ Object
102
103
104
105
106
107
108
109
110
111
112
113
114
|
# File 'lib/active_ldap/adapter/net_ldap.rb', line 102
def add(dn, entries, options={})
super do |_dn, _entries|
attributes = {}
_entries.each do |type, key, attrs|
attrs.each do |name, values|
attributes[name] = values
end
end
args = {:dn => _dn, :attributes => attributes}
info = args.dup
execute(:add, info, args)
end
end
|
#bind(options = {}) ⇒ Object
56
57
58
59
60
61
62
|
# File 'lib/active_ldap/adapter/net_ldap.rb', line 56
def bind(options={})
begin
super
rescue Net::LDAP::Error
raise AuthenticationError, $!.message
end
end
|
#bind_as_anonymous(options = {}) ⇒ Object
64
65
66
67
68
69
|
# File 'lib/active_ldap/adapter/net_ldap.rb', line 64
def bind_as_anonymous(options={})
super do
execute(:bind, {:name => "bind: anonymous"}, {:method => :anonymous})
true
end
end
|
#connect(options = {}) ⇒ Object
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
# File 'lib/active_ldap/adapter/net_ldap.rb', line 23
def connect(options={})
super do |host, port, method|
config = {
:host => host,
:port => port,
}
if method
config[:encryption] = { :method => method }
config[:encryption][:tls_options] = @tls_options if @tls_options
end
begin
uri = construct_uri(host, port, method == :simple_tls)
with_start_tls = method == :start_tls
info = {:uri => uri, :with_start_tls => with_start_tls}
[log("connect", info) {Net::LDAP::Connection.new(config)},
uri, with_start_tls]
rescue Net::LDAP::ConnectionError => error
raise ConnectionError, error.message
rescue Net::LDAP::Error => error
message = "#{error.class}: #{error.message}"
raise ConnectionError, message, caller(0) + error.backtrace
end
end
end
|
#delete(targets, options = {}) ⇒ Object
94
95
96
97
98
99
100
|
# File 'lib/active_ldap/adapter/net_ldap.rb', line 94
def delete(targets, options={})
super do |target|
args = {:dn => target}
info = args.dup
execute(:delete, info, args)
end
end
|
#modify(dn, entries, options = {}) ⇒ Object
116
117
118
119
120
121
122
123
|
# File 'lib/active_ldap/adapter/net_ldap.rb', line 116
def modify(dn, entries, options={})
super do |_dn, _entries|
info = {:dn => _dn, :attributes => _entries}
execute(:modify, info,
:dn => _dn,
:operations => parse_entries(_entries))
end
end
|
#modify_rdn(dn, new_rdn, delete_old_rdn, new_superior, options = {}) ⇒ Object
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
|
# File 'lib/active_ldap/adapter/net_ldap.rb', line 125
def modify_rdn(dn, new_rdn, delete_old_rdn, new_superior, options={})
super do |_dn, _new_rdn, _delete_old_rdn, _new_superior|
info = {
:name => "modify: RDN",
:dn => _dn,
:new_rdn => _new_rdn,
:new_superior => _new_superior,
:delete_old_rdn => _delete_old_rdn
}
execute(:rename, info,
:olddn => _dn,
:newrdn => _new_rdn,
:delete_attributes => _delete_old_rdn,
:new_superior => _new_superior)
end
end
|
#search(options = {}) ⇒ Object
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
|
# File 'lib/active_ldap/adapter/net_ldap.rb', line 71
def search(options={})
super(options) do |search_options|
scope = search_options[:scope]
info = search_options.merge(scope: scope_name(scope))
args = {
base: search_options[:base],
scope: scope,
filter: search_options[:filter],
attributes: search_options[:attributes],
size: search_options[:limit],
paged_searcheds_supported: search_options[:paged_results_supported],
}
execute(:search, info, args) do |entry|
attributes = {}
entry.original_attribute_names.each do |name|
value = entry[name]
attributes[name] = value if value
end
yield([entry.dn, attributes])
end
end
end
|
#unbind(options = {}) ⇒ Object
48
49
50
51
52
53
54
|
# File 'lib/active_ldap/adapter/net_ldap.rb', line 48
def unbind(options={})
super do
log("unbind") do
@connection.close end
end
end
|