среда, 1 декабря 2010 г.

LDAP для apache с авторизацией.

Не могу претендовать на how to, но по крайней мере есть нюансы, которые отмечу. В общем потребовался мне apache с авторизацией в LDAP и с этого все началось.

Установка LDAP стандартная, интересное начинается с его настройки. Речь тут идет об OpenLDAP и дистрибутиве Gentoo. Основной файл настроек находится в каталоге /etc/openldap/ и называется slapd.conf. Для работы необходимо настроить минимум:

#/etc/openldap/slapd.conf
#
# Подключаем базовые схемы
#
include /etc/openldap/schema/core.schema
include /etc/openldap/schema/cosine.schema
include /etc/openldap/schema/inetorgperson.schema
include /etc/openldap/schema/nis.schema
#
# Это права доступа по умолчанию, надо потом исправить, т.к.
# т.к. любой может исправить любую запись. Так что после первичной
# настройке не забудьте исправить.
#
access to dn.base="" by * read
access to dn.base="cn=Subschema" by * read
access to *
by self write
by users read
by anonymous auth

#######################################################################
# BDB database definitions - Дальше описание базы.
#######################################################################
#
# формат файла базы
database hdb
# Это указание корня ldap каталога в базе
suffix "dc=site,dc=local"
#
checkpoint 32 30
# имя пользователя который будет управлять корнем
rootdn "cn=glav,dc=site,dc=local"
# Пароль от rootdn в зашифрованном виде
rootpw {SSHA}ххххххххххххххххххххх
# Каталог, в котором будет размещена база ldap
directory /var/lib/openldap-data
# индексы
index objectClass eq

Шифрованный пароль для rootdn можно получить сразу, выполнив команду slappasswd -h {MD5}.

При старте ldap у меня сразу не создалась БД и /etc/init.d/slapd start валился с ошибкой. Я скопировал /var/lib/openldap-data/DB_CONFIG из файла DB_CONFIG.example и все запустилось.

После этого через ldif файлы я заполнил необходимой информацией каталог. В общем все просто, но даже по прочтении кучи документации я не возьмусь кому нибудь, кроме себя, объяснять как все это работает и что я для этого сделал =). Основная проблема в том, что для использования ldap нужно понимать что из себя представляет ldap!

Для тестовых целей создадин OU (Organization Unit) добавим пользователя, группу и поместим пользователя в эту группу. В дальнейшем на этом примере напишу конфигурацию в apache.

Для добавления записей в ldap каталог, используется утилита ldapadd на вход которой передаем ldif файлы с необходимыми данными. LDIF - формат представления записей службы каталогов или их изменений в текстовой форме.

Для начала добавим OU для пользователей и групп, OU будет называться O1:

#ou.ldif
dn: ou=O1,dc=site,dc=local
objectclass: organizationalUnit
objectclass: top
ou: O1


Командой ldapadd ou.ldif данные заносятся к каталог. Аналогичным образом создаем пользователя U1:

#u1.ldif
dn: uid=pet,ou=O1,dc=site,dc=local
cn: Victor Veseli
objectclass: inetOrgPerson
objectclass: simpleSecurityObject
objectclass: top
sn: Veseli
uid: g1
userpassword: {MD5}ХХХХХХХХХХХХ



Теперь добавляем группу G1 и заносим в нее пользователя U1:

#g1.ldif
dn: cn=G1,ou=O1,dc=site,dc=local
cn: G1
objectclass: groupOfUniqueNames
objectclass: top
uniquemember: uid=pet,ou=O1,dc=site,dc=local


В итоге имеем в ldap каталоге одного пользователя u1 входящего в группу g1 в подразделении o1.

Комментариев нет: