OpenLDAP Server on Debian or Ubuntu
1 Preliminary Note
This tutorial is based on Debian 7.6 server, so you should set up a basic Debian 7.6 server installation before you continue with this tutorial. The system should have a static IP address. I use 192.168.0.100 as my IP address in this tutorial and server1.example.com as the hostname. I am using root credentials for installations, you can use sudo before the commands if you are installing it without root.
Note:The guide can be used for both Ubuntu/Debian server.
2 Install OpenLDAP
2.1 OpenLDAP installation
We will install OpenLDAP as follows:
apt-get update
apt-get install slapd ldap-utils
apt-get install slapd ldap-utils
data:image/s3,"s3://crabby-images/3fe1d/3fe1d2aa0ba8de7111aea94e33b563a83a22a2e3" alt=""
Put the password and press OK. I am using password howtoforge, input your desired password.
data:image/s3,"s3://crabby-images/99bc0/99bc0add0e7ee040820329d62978690b00208acb" alt=""
Confirm the password and press OK.
2.2 OpenLDAP Configuration
Now we will edit the configuration file to make the OpenLDAP server according to our environment.
nano /etc/ldap/ldap.conf
Give the entries as follows:# # LDAP Defaults # # See ldap.conf(5) for details # This file should be world readable but not world writable. BASE dc=example,dc=com URI ldap://192.168.0.100 ldap://192.168.0.100:666 #SIZELIMIT 12 #TIMELIMIT 15 #DEREF never # TLS certificates (needed for GnuTLS) TLS_CACERT /etc/ssl/certs/ca-certificates.crt |
Note in my case hostname was server1.example.com so my dc=example and dc=com
Save the file and run the following command to reconfigure the LDAP package.
dpkg-reconfigure slapd
It will ask some questionnaire, we will choose the values as follows:
data:image/s3,"s3://crabby-images/2e4b6/2e4b6ce537a8f8d7cee7cf54d1b33721be1bd8fd" alt=""
Select No:
data:image/s3,"s3://crabby-images/929e5/929e59735ba401c9f8f77cdeba6ca26031389a86" alt=""
Select Ok:
data:image/s3,"s3://crabby-images/6b9a4/6b9a4bd16c871026d78338286b455cff85f549ca" alt=""
Give any name as per your needs, in my case I am using Test-company as the company name. Further press Ok.
data:image/s3,"s3://crabby-images/1971e/1971e15ca4b64b2eff69350136a30bdbb5d5dc97" alt=""
Give an administrative password, and confirm the same.
data:image/s3,"s3://crabby-images/91ac6/91ac6e0b049d1a2f73f9219d4508e25054004adb" alt=""
data:image/s3,"s3://crabby-images/ca522/ca522d0887097cf9be268bc5c275caa1ea08f4d2" alt=""
Select HDB and press Ok.
data:image/s3,"s3://crabby-images/713e7/713e7d0ac443b1b8e0b86c4abede095fd7cf4b7e" alt=""
Select Yes.
data:image/s3,"s3://crabby-images/d3ae2/d3ae2c132e8550f62a2ba38dc9f2dbd1e25bfd7a" alt=""
Again select Yes and move the old database files.
data:image/s3,"s3://crabby-images/426d8/426d8f3d8a2caddfaac04844493a3d61227657b4" alt=""
We don't want to use LDAPv2 protocol so select No. Now we are done with the configuration, we can check that our installation have all gone well with the command:
ldapsearch -x
It will show output like this:root@server1:~# ldapsearch -x
# extended LDIF
#
# LDAPv3
# base <dc=example,dc=com> (default) with scope subtree
# filter: (objectclass=*)
# requesting: ALL
#
# example.com
dn: dc=example,dc=com
objectClass: top
objectClass: dcObject
objectClass: organization
o: Test-company
dc: example
# admin, example.com
dn: cn=admin,dc=example,dc=com
objectClass: simpleSecurityObject
objectClass: organizationalRole
cn: admin
description: LDAP administrator
# search result
search: 2
result: 0 Success
# numResponses: 3
# numEntries: 2
root@server1:~#
It shows successful configuration for the OpenLDAP server.
3 phpLDAPadmin installation
We can administrate the OpenLDAP with commands, but to make it an easier task I will install phpLDAPadmin. We need to have an Apache server and php installed before phpLDAPadmin installation:
apt-get install apache2 php5 php5-mysql
Next we can install phpLDAPadmin as follows:
apt-get install phpldapadmin
Now we need to modify phpLDAPadmin in accordance to our server requirement so that it will get controlled through it, edit the file /etc/phpldapadmin/config.php and give the values like this:
nano /etc/phpldapadmin/config.php
Values will be like this:
[...]
$servers = new Datastore();
$servers->newServer('ldap_pla');
$servers->setValue('server','name','Test-company LDAP');
$servers->setValue('server','host','127.0.0.1');
$servers->setValue('server','base',array('dc=example,dc=com'));
$servers->setValue('login','bind_id','cn=admin,dc=example,dc=com');
?>
|
Note: In above file dc will vary according to your hostname, i have given my company name as Test-company you can use other name as per your choice.
Now open the link http://192.168.0.100/phpldapadmin in any browser of your choice.
data:image/s3,"s3://crabby-images/c2d96/c2d9694f66722bb5efc7a0ffd60428d48df1dc59" alt=""
data:image/s3,"s3://crabby-images/c302b/c302bf157a18fd92500ee4894f700a38d8e8a046" alt=""
Put the password used at the time of modifying the LDAP, in my case user=admin(it is preselected) and password=howtoforge.
data:image/s3,"s3://crabby-images/1696e/1696e6343f7973cd9d4569f4f8c8cd330f60f3ef" alt=""
It will be your default welcome page.
4 Adding accounts in LDAP
Next we will create a test entry in the LDAP server and verify the settings in admin panel itself. Suppose we are in a corporate company and we want to classify different teams with different team stucture, such as Teachnical-team, Accounts Department an HR department etc. Now click on+ sign dc=example, dc=com and at cn=admin select Create a child entry.data:image/s3,"s3://crabby-images/d527f/d527fd4ae80b5628bd5ca44f027bfe76156c4d73" alt=""
To have such functionality in LDAP select Generic: Posix Group
data:image/s3,"s3://crabby-images/5def9/5def9f074b6401b71dc5935fabe09826e6f2ac75" alt=""
Next you will be redirected as:
data:image/s3,"s3://crabby-images/13490/1349060ccc28ed1882f612b48ff3086a107a5f39" alt=""
I am just taking an example, and adding a test entry for Technical-team as my group. Press Create Object.
data:image/s3,"s3://crabby-images/f571b/f571bed0a621bc616a9a6ca78ad9c6a1bbe0bc28" alt=""
Verify the things and Press Commit.
data:image/s3,"s3://crabby-images/e672f/e672fbf92e970a28e6ed4e28c68e061d814a086b" alt=""
It will create the group As Technical-team, similarily we can create other groups as per our corporate structure.
data:image/s3,"s3://crabby-images/8fd76/8fd76676231c85bd6f9aaaa040509eb6e94a0fcc" alt=""
We can check the groups under cn=admin similarily add other groups as per our needs.
Congratulations! Now we have successfully configured OpenLDAP in Debian Wheezy :)
5 Links
- Debian : https://www.debian.org/
- Ubuntu : http://www.ubuntu.com/
- OpenLDAP : http://www.openldap.org/
Comments
Post a Comment