openldap/contrib/slapd-modules/passwd/totp
Quanah Gibson-Mount 6c4d6c880b Happy New Year!
2016-01-29 13:32:05 -06:00
..
Makefile Add TOTP pw mechanism 2015-07-02 17:05:14 +01:00
README Happy New Year! 2016-01-29 13:32:05 -06:00
slapd-totp.c Happy New Year! 2016-01-29 13:32:05 -06:00

TOTP OpenLDAP support
----------------------

slapd-totp.c provides support for RFC 6238 TOTP Time-based One
Time Passwords in OpenLDAP using SHA-1, SHA-256, and SHA-512.
For instance, one could have the LDAP attribute:

userPassword: {TOTP1}GEZDGNBVGY3TQOJQGEZDGNBVGY3TQOJQ

which encodes the key '12345678901234567890'.


Building
--------

1) Customize the LDAP_SRC variable in Makefile to point to the OpenLDAP
source root.

2) Run 'make' to produce slapd-totp.so

3) Copy slapd-totp.so somewhere permanent.

4) Edit your slapd.conf (eg. /etc/ldap/slapd.conf), and add:

moduleload ...path/to/slapd-sha2.so

5) This module replaces the function of the slapo-lastbind overlay. You
cannot use that overlay on the same database as this one.

6) Restart slapd.


Configuring
-----------

The {TOTP1}, {TOTP256}, and {TOTP512} password schemes should now be recognised.

You can also tell OpenLDAP to use one of these new schemes when processing LDAP
Password Modify Extended Operations, thanks to the password-hash option in
slapd.conf. For example:

password-hash	{TOTP1}

On the databases where your users reside you must configure both the
lastbind overlay and the totp overlay:

database mdb
...

overlay totp



Testing
-------

The TOTP1 algorithm is compatible with Google Authenticator.

---

This work is part of OpenLDAP Software <http://www.openldap.org/>.

Copyright 2015-2016 The OpenLDAP Foundation.
Portions Copyright 2015 by Howard Chu, Symas Corp.
All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted only as authorized by the OpenLDAP
Public License.

A copy of this license is available in the file LICENSE in the
top-level directory of the distribution or, alternatively, at
<http://www.OpenLDAP.org/license.html>.