Аутентификация SSSD с Samba 4

Недавно я обновился до samba 4 с samba 3.5 на платформе RHEL 6.3. Приятно, что новая версия может заменить AD DC и имеет собственную встроенную базу данных kdc и ldb. Теперь я намерен сделать так, чтобы Linux-ящики аутентифицировались для samba4, подключаясь через ldap, поскольку samba 4 работает как керберизованный ldap-сервер. Я могу подключиться с помощью студии каталогов Apache, используя dn администратора к базе данных ldap. Однако я не могу правильно настроить sssd на клиентских машинах RHEL 6 для аутентификации на сервере samba через ldap. Вот мой файл конфигурации sssd -

[sssd]
config_file_version = 2
reconnection_retries = 3
sbus_timeout = 30
services = nss, pam
domains = default

[nss]
filter_groups = root
filter_users = root
reconnection_retries = 3

[pam]
reconnection_retries = 3

[domain/default]
ldap_default_authtok_type = password
ldap_id_use_start_tls = False
cache_credentials = True
ldap_group_object_class = group
ldap_search_base = <My Domain dn>
chpass_provider = krb5
ldap_default_authtok = <Administrator Password>
id_provider = ldap
auth_provider = krb5
ldap_default_bind_dn = cn=Administrator,cn=Users,<My Domain dn>
ldap_user_gecos = displayName
debug_level = 0
ldap_uri = ldap://<samba_server_hostname>/
krb5_realm = <krb auth realm(same as domain name)>
krb5_kpasswd = <samba_server_hostname>
ldap_schema = rfc2307bis
ldap_force_upper_case_realm = True
ldap_user_object_class = person
ldap_tls_cacertdir = /etc/openldap/cacerts
krb5_kdcip = <samba_server_hostname>

Я могу успешно запустить kinit для администратора на клиенте, и я могу запустить ldapsearch при привязке в качестве администратора, но id или getent passwd для любого пользователя не работают. Любые идеи, пожалуйста ??


person user1600936    schedule 16.09.2013    source источник


Ответы (1)


Наконец-то у меня все заработало. Оказывается, запись пользователя в базе данных ldb не имеет атрибутов posixAccount objectclass и uidNumber / gidnumber. После их добавления и перекомпиляции samba4 с поддержкой gnu-tls linux может аутентифицироваться в samba4 AD DC, как если бы аутентифицировался в базе данных ldap через tls. Думаю, мне придется написать сценарий для добавления необходимых объектных классов и атрибутов к каждой пользовательской записи сразу после их добавления.

person user1600936    schedule 30.09.2013