1 # $OpenLDAP: pkg/openldap-guide/admin/security.sdf,v 1.16.2.8 2008/05/29 16:19:01 quanah Exp $
2 # Copyright 1999-2008 The OpenLDAP Foundation, All Rights Reserved.
3 # Portions Copyright 2008 Andrew Findlay.
4 # COPYING RESTRICTIONS APPLY, see COPYRIGHT.
6 H1: Security Considerations
8 OpenLDAP Software is designed to run in a wide variety of computing
9 environments from tightly-controlled closed networks to the global
10 Internet. Hence, OpenLDAP Software supports many different security
11 mechanisms. This chapter describes these mechanisms and discusses
12 security considerations for using OpenLDAP Software.
16 H3: Selective Listening
18 By default, {{slapd}}(8) will listen on both the IPv4 and IPv6 "any"
19 addresses. It is often desirable to have {{slapd}} listen on select
20 address/port pairs. For example, listening only on the IPv4 address
21 {{EX:127.0.0.1}} will disallow remote access to the directory server.
24 > slapd -h ldap://127.0.0.1
26 While the server can be configured to listen on a particular interface
27 address, this doesn't necessarily restrict access to the server to
28 only those networks accessible via that interface. To selective
29 restrict remote access, it is recommend that an {{SECT:IP Firewall}}
30 be used to restrict access.
32 See {{SECT:Command-line Options}} and {{slapd}}(8) for more
38 {{TERM:IP}} firewall capabilities of the server system can be used
39 to restrict access based upon the client's IP address and/or network
40 interface used to communicate with the client.
42 Generally, {{slapd}}(8) listens on port 389/tcp for {{F:ldap://}}
43 sessions and port 636/tcp for {{F:ldaps://}}) sessions. {{slapd}}(8)
44 may be configured to listen on other ports.
46 As specifics of how to configure IP firewall are dependent on the
47 particular kind of IP firewall used, no examples are provided here.
48 See the document associated with your IP firewall.
53 {{slapd}}(8) supports {{TERM:TCP}} Wrappers. TCP Wrappers provide
54 a rule-based access control system for controlling TCP/IP access
55 to the server. For example, the {{host_options}}(5) rule:
57 > slapd: 10.0.0.0/255.0.0.0 127.0.0.1 : ALLOW
60 allows only incoming connections from the private network {{F:10.0.0.0}}
61 and localhost ({{F:127.0.0.1}}) to access the directory service.
63 Note: IP addresses are used as {{slapd}}(8) is not normally
64 configured to perform reverse lookups.
66 It is noted that TCP wrappers require the connection to be accepted.
67 As significant processing is required just to deny a connection,
68 it is generally advised that IP firewall protection be used instead
71 See {{hosts_access}}(5) for more information on TCP wrapper rules.
74 H2: Data Integrity and Confidentiality Protection
76 {{TERM[expand]TLS}} (TLS) can be used to provide data integrity and
77 confidentiality protection. OpenLDAP supports negotiation of
78 {{TERM:TLS}} ({{TERM:SSL}}) via both StartTLS and {{F:ldaps://}}.
79 See the {{SECT:Using TLS}} chapter for more information. StartTLS
80 is the standard track mechanism.
82 A number of {{TERM[expand]SASL}} (SASL) mechanisms, such as
83 {{TERM:DIGEST-MD5}} and {{TERM:GSSAPI}}, also provide data integrity
84 and confidentiality protection. See the {{SECT:Using SASL}} chapter
88 H3: Security Strength Factors
90 The server uses {{TERM[expand]SSF}}s (SSF) to indicate the relative
91 strength of protection. A SSF of zero (0) indicates no protections
92 are in place. A SSF of one (1) indicates integrity protection are
93 in place. A SSF greater than one (>1) roughly correlates to the
94 effective encryption key length. For example, {{TERM:DES}} is 56,
95 {{TERM:3DES}} is 112, and {{TERM:AES}} 128, 192, or 256.
97 A number of administrative controls rely on SSFs associated with
98 TLS and SASL protection in place on an LDAP session.
100 {{EX:security}} controls disallow operations when appropriate
101 protections are not in place. For example:
103 > security ssf=1 update_ssf=112
105 requires integrity protection for all operations and encryption
106 protection, 3DES equivalent, for update operations (e.g. add, delete,
107 modify, etc.). See {{slapd.conf}}(5) for details.
109 For fine-grained control, SSFs may be used in access controls.
110 See {{SECT:The access Configuration Directive}} section of the
111 {{SECT:The slapd Configuration File}} for more information.
114 H2: Authentication Methods
118 The LDAP "simple" method has three modes of operation:
121 * unauthenticated, and
122 * user/password authenticated.
124 Anonymous access is requested by providing no name and no password
125 to the "simple" bind operation. Unauthenticated access is requested
126 by providing a name but no password. Authenticated access is
127 requested by providing a valid name and password.
129 An anonymous bind results in an {{anonymous}} authorization
130 association. Anonymous bind mechanism is enabled by default, but
131 can be disabled by specifying "{{EX:disallow bind_anon}}" in
134 Note: Disabling the anonymous bind mechanism does not prevent
135 anonymous access to the directory. To require authentication to
136 access the directory, one should instead specify "{{EX:require authc}}".
138 An unauthenticated bind also results in an {{anonymous}} authorization
139 association. Unauthenticated bind mechanism is disabled by default,
140 but can be enabled by specifying "{{EX:allow bind_anon_cred}}" in
141 {{slapd.conf}}(5). As a number of LDAP applications mistakenly
142 generate unauthenticated bind request when authenticated access was
143 intended (that is, they do not ensure a password was provided),
144 this mechanism should generally remain disabled.
146 A successful user/password authenticated bind results in a user
147 authorization identity, the provided name, being associated with
148 the session. User/password authenticated bind is enabled by default.
149 However, as this mechanism itself offers no eavesdropping protection
150 (e.g., the password is set in the clear), it is recommended that
151 it be used only in tightly controlled systems or when the LDAP
152 session is protected by other means (e.g., TLS, {{TERM:IPsec}}).
153 Where the administrator relies on TLS to protect the password, it
154 is recommended that unprotected authentication be disabled. This
155 is done using the {{EX:security}} directive's {{EX:simple_bind}}
156 option, which provides fine grain control over the level of confidential
157 protection to require for {{simple}} user/password authentication.
158 E.g., using {{EX:security simple_bind=56}} would require {{simple}}
159 binds to use encryption of DES equivalent or better.
161 The user/password authenticated bind mechanism can be completely
162 disabled by setting "{{EX:disallow bind_simple}}".
164 Note: An unsuccessful bind always results in the session having
165 an {{anonymous}} authorization association.
170 The LDAP {{TERM:SASL}} method allows the use of any SASL authentication
171 mechanism. The {{SECT:Using SASL}} section discusses the use of SASL.
175 LDAP passwords are normally stored in the {{userPassword}} attribute.
176 {{REF:RFC4519}} specifies that passwords are not stored in encrypted
177 (or hashed) form. This allows a wide range of password-based
178 authentication mechanisms, such as {{EX:DIGEST-MD5}} to be used.
179 This is also the most interoperable storage scheme.
181 However, it may be desirable to store a hash of password instead.
182 {{slapd}}(8) supports a variety of storage schemes for the administrator
185 Note: Values of password attributes, regardless of storage scheme
186 used, should be protected as if they were clear text. Hashed
187 passwords are subject to {{dictionary attacks}} and {{brute-force
190 The {{userPassword}} attribute is allowed to have more than one value,
191 and it is possible for each value to be stored in a different form.
192 During authentication, {{slapd}} will iterate through the values
193 until it finds one that matches the offered password or until it
194 runs out of values to inspect. The storage scheme is stored as a prefix
195 on the value, so a hashed password using the Salted SHA1 ({{EX:SSHA}})
198 > userPassword: {SSHA}DkMTwBl+a/3DQTxCYEApdUtNXGgdUac3
200 The advantage of hashed passwords is that an attacker which
201 discovers the hash does not have direct access to the actual password.
202 Unfortunately, as dictionary and brute force attacks are generally
203 quite easy for attackers to successfully mount, this advantage is
204 marginal at best (this is why all modern Unix systems use shadow
207 The disadvantages of hashed storage is that they are non-standard, may
208 cause interoperability problem, and generally preclude the use
209 of stronger than Simple (or SASL/PLAIN) password-based authentication
210 mechanisms such as {{EX:DIGEST-MD5}}.
212 H3: SSHA password storage scheme
214 This is the salted version of the SHA scheme. It is believed to be the
215 most secure password storage scheme supported by {{slapd}}.
217 These values represent the same password:
219 > userPassword: {SSHA}DkMTwBl+a/3DQTxCYEApdUtNXGgdUac3
220 > userPassword: {SSHA}d0Q0626PSH9VUld7yWpR0k6BlpQmtczb
222 H3: CRYPT password storage scheme
224 This scheme uses the operating system's {{crypt(3)}} hash function.
225 It normally produces the traditional Unix-style 13 character hash, but
226 on systems with {{EX:glibc2}} it can also generate the more secure
229 > userPassword: {CRYPT}aUihad99hmev6
230 > userPassword: {CRYPT}$1$czBJdDqS$TmkzUAb836oMxg/BmIwN.1
232 The advantage of the CRYPT scheme is that passwords can be
233 transferred to or from an existing Unix password file without having
234 to know the cleartext form. Both forms of {{crypt}} include salt so
235 they have some resistance to dictionary attacks.
237 Note: Since this scheme uses the operating system's {{crypt(3)}}
238 hash function, it is therefore operating system specific.
240 H3: MD5 password storage scheme
242 This scheme simply takes the MD5 hash of the password and stores it in
245 > userPassword: {MD5}Xr4ilOzQ4PCOq3aQ0qbuaQ==
247 Although safer than cleartext storage, this is not a very secure
248 scheme. The MD5 algorithm is fast, and because there is no salt the
249 scheme is vulnerable to a dictionary attack.
251 H3: SMD5 password storage scheme
253 This improves on the basic MD5 scheme by adding salt (random data
254 which means that there are many possible representations of a given
255 plaintext password). For example, both of these values represent the
258 > userPassword: {SMD5}4QWGWZpj9GCmfuqEvm8HtZhZS6E=
259 > userPassword: {SMD5}g2/J/7D5EO6+oPdklp5p8YtNFk4=
261 H3: SHA password storage scheme
263 Like the MD5 scheme, this simply feeds the password through an SHA
264 hash process. SHA is thought to be more secure than MD5, but the lack
265 of salt leaves the scheme exposed to dictionary attacks.
267 > userPassword: {SHA}5en6G6MezRroT3XKqkdPOmY/BfQ=
269 H3: SASL password storage scheme
271 This is not really a password storage scheme at all. It uses the
272 value of the {{userPassword}} attribute to delegate password
273 verification to another process. See below for more information.
275 Note: This is not the same as using SASL to authenticate the LDAP
278 H3: KERBEROS password storage scheme
280 This is not really a password storage scheme at all. It uses the
281 value of the {{userPassword}} attribute to delegate password
282 verification to Kerberos.
284 Note: This is not the same as using Kerberos authentication of
287 This scheme could be said to defeat the advantages of Kerberos by
288 causing the Kerberos password to be exposed to the {{slapd}} server
289 (and possibly on the network as well).
291 H2: Pass-Through authentication
293 Since OpenLDAP 2.0 {{slapd}} has had the ability to delegate password
294 verification to a separate process. This uses the {{sasl_checkpass(3)}}
295 function so it can use any back-end server that Cyrus SASL supports for
296 checking passwords. The choice is very wide, as one option is to use
297 {{saslauthd(8)}} which in turn can use local files, Kerberos, an IMAP
298 server, another LDAP server, or anything supported by the PAM mechanism.
300 The server must be built with the {{EX:--enable-spasswd}}
301 configuration option to enable pass-through authentication.
303 Note: This is not the same as using a SASL mechanism to
304 authenticate the LDAP session.
306 Pass-Through authentication works only with plaintext passwords, as
307 used in the "simple bind" and "SASL PLAIN" authentication mechanisms.}}
309 Pass-Through authentication is selective: it only affects users whose
310 {{userPassword}} attribute has a value marked with the "{SASL}"
311 scheme. The format of the attribute is:
313 > userPassword: {SASL}username@realm
315 The {{username}} and {{realm}} are passed to the SASL authentication
316 mechanism and are used to identify the account whose password is to be
317 verified. This allows arbitrary mapping between entries in OpenLDAP
318 and accounts known to the backend authentication service.
320 Note: There is no support for changing passwords in the backend
323 It would be wise to use access control to prevent users from changing
324 their passwords through LDAP where they have pass-through authentication
328 H3: Configuring slapd to use an authentication provider
330 Where an entry has a "{SASL}" password value, OpenLDAP delegates the
331 whole process of validating that entry's password to Cyrus SASL. All
332 the configuration is therefore done in SASL config files.
335 file to be considered is confusingly named {{slapd.conf}} and is
336 typically found in the SASL library directory, often
337 {{EX:/usr/lib/sasl2/slapd.conf}} This file governs the use of SASL
338 when talking LDAP to {{slapd}} as well as the use of SASL backends for
339 pass-through authentication. See {{EX:options.html}} in the {{PRD:Cyrus SASL}}
340 docs for full details. Here is a simple example for a server that will
341 use {{saslauthd}} to verify passwords:
344 > pwcheck_method: saslauthd
345 > saslauthd_path: /var/run/sasl2/mux
347 H3: Configuring saslauthd
349 {{saslauthd}} is capable of using many different authentication
350 services: see {{saslauthd(8)}} for details. A common requirement is to
351 delegate some or all authentication to another LDAP server. Here is a
352 sample {{EX:saslauthd.conf}} that uses Microsoft Active Directory (AD):
354 > ldap_servers: ldap://dc1.example.com/ ldap://dc2.example.com/
356 > ldap_search_base: cn=Users,DC=ad,DC=example,DC=com
357 > ldap_filter: (userPrincipalName=%u)
359 > ldap_bind_dn: cn=saslauthd,cn=Users,DC=ad,DC=example,DC=com
360 > ldap_password: secret
362 In this case, {{saslauthd}} is run with the {{EX:ldap}} authentication
363 mechanism and is set to combine the SASL realm with the login name:
365 > saslauthd -a ldap -r
367 This means that the "username@realm" string from the {{userPassword}}
368 attribute ends up being used to search AD for
369 "userPrincipalName=username@realm" - the password is then verified by
370 attempting to bind to AD using the entry found by the search and the
371 password supplied by the LDAP client.
373 H3: Testing pass-through authentication
375 It is usually best to start with the back-end authentication provider
376 and work through {{saslauthd}} and {{slapd}} towards the LDAP client.
378 In the AD example above, first check that the DN and password that
379 {{saslauthd}} will use when it connects to AD are valid:
381 > ldapsearch -x -H ldap://dc1.example.com/ \
382 > -D cn=saslauthd,cn=Users,DC=ad,DC=example,DC=com \
387 Next check that a sample AD user can be found:
389 > ldapsearch -x -H ldap://dc1.example.com/ \
390 > -D cn=saslauthd,cn=Users,DC=ad,DC=example,DC=com \
392 > -b cn=Users,DC=ad,DC=example,DC=com \
393 > "(userPrincipalName=user@ad.example.com)"
395 Check that the user can bind to AD:
397 > ldapsearch -x -H ldap://dc1.example.com/ \
398 > -D cn=user,cn=Users,DC=ad,DC=example,DC=com \
400 > -b cn=user,cn=Users,DC=ad,DC=example,DC=com \
404 If all that works then {{saslauthd}} should be able to do the same:
406 > testsaslauthd -u user@ad.example.com -p userpassword
407 > testsaslauthd -u user@ad.example.com -p wrongpassword
409 Now put the magic token into an entry in OpenLDAP:
411 > userPassword: {SASL}user@ad.example.com
413 It should now be possible to bind to OpenLDAP using the DN of that
414 entry and the password of the AD user.