HowTo validación LDAP

De Tutoriales de Informatica
Saltar a: navegación, buscar

Paquetes a instalar

Los paquetes mencionados a continuación son necesarios para validar por LDAP.

apt-get install libpam-ldap libnss-ldap nss-updatedb libnss-db ldap-utils libpam-dotfile


Configuración

libnss-ldap

Al instalar el paquete libnss-ldap, nos aparecen las siguientes pantallas de configuración.

La primera pregunta que nos hace el asistente es quién es el servidor LDAP. Podemos poner la IP o el nombre:

Pantalla N°1


















Luego nos preguntará por la base del directorio LDAP (base DN):

dc=midominio,dc=com,dc=ar

Pantalla N°2


















Acto seguido tendremos que indicar la versión de LDAP a utilizar:

la más actual es la 3 por defecto.

Pantalla N°3


















En el siguiente paso nos pregunta si necesitamos autentificarnos en el servidor LDAP o no. Como la librería únicamente va a realizar consultas, no es necesario autentificarse por lo tanto debemos responder 'No':

Pantalla N°4


















Posteriormente nos preguntará si el archivo /etc/libnss-ldap (o /etc/ldap.conf en versiones recientes) debe solamente tener permisos de lectura y escritura para el usuario (root que es quién instala) o no. Como en el paso anterior hemos indicado que no necesitamos autentificación, no se almacenarán contraseñas en el archivo de configuración, por tanto podemos responder 'No':

Pantalla N°5


















Finalmente nos advierte que debemos modificar el archivo /etc/nsswitch.conf para que el sistema utilice el directorio LDAP como base de datos del sistema, al igual que hace con los archivos passwd, group y shadow:

Pantalla N°6
















libpam-ldap

Para configurar este paquete, ejecutamos lo siguiente:

 dpkg-reconfigure libpam-ldap 

La primera pregunta que nos hace el asistente es quién es el servidor LDAP. Podemos poner la IP o el nombre:

Pantalla N°1
















Luego nos preguntará por la base del directorio LDAP (base DN):


Pantalla N°2
















Acto seguido tendremos que indicar la versión de LDAP a utilizar:

la más actual es la 3 por defecto.

Pantalla N°3
















Ahora nos pregunta si queremos que el usuario administrador del ldap se comporte como administrador local

Pantalla N°4
















Nos pregunta si hace falta un usuario para acceder a la base ldap

Pantalla N°5















Solicita la cuenta de validación lDAP

Contraseña del usuario

Pantalla N°7
















Nos avisa que el modulo PAM puede cifrar la contraseña.

Pantalla N°8















Elegimos el algoritmo de cifrado

Pantalla N°9















Nos informa sobre el papel del modulo PAM en la validación.

Pantalla N°10















Perfiles PAM para habilitar

Pantalla N°11














.

Otras configuraciones

Para que el servidor LDAP actúe como si se tratara de los archivos passwd, group y shadow, además de instalar las librerías anteriores, debemos indicar que se utilice LDAP como alternativa para autentificar usuarios. Para ello hay que añadir en las líneas que hacen referencia a passwd, group y shadow en el archivo /etc/nsswitch.conf, la palabra 'ldap' tras la palabra 'compat' quedando el archivo /etc/nsswitch.conf así:

// Archivo /etc/nsswitch.conf

   # /etc/nsswitch.conf
   #
   # Example configuration of GNU Name Service Switch functionality.
   # If you have the `glibc-doc' and `info' packages installed, try:
   # `info libc "Name Service Switch"' for information about this file.
   passwd: files ldap
   group: files ldap
   shadow: files ldap
   hosts: files dns
   networks: files
   protocols: db files
   services: db files
   ethers: db files
   rpc: db files
   netgroup: nis

A continuación vamos a configurar LDAP como cliente.

// Archivo /etc/ldap/ldap.conf

   #
   # LDAP Defaults
   #
   # See ldap.conf(5) for details
   # This file should be world readable but not world writable.
   BASE	cn=correo,cn=admin,dc=midominio,dc=com,dc=ar
   #URI	ldap://ldap.midominio.com.ar
   #SIZELIMIT	12
   #TIMELIMIT	15
   #DEREF		never

A continuación vamos a configurar LDAP como cliente.

// Archivo /etc/libnss-ldap.conf

   #
   # the configuration of this file will be done by debconf as long as the
   # first line of the file says '###DEBCONF###'
   #
   # you should use dpkg-reconfigure libnss-ldap to configure this file.
   #
   # @(#)$Id: ldap.conf,v 2.48 2008/07/03 02:30:29 lukeh Exp $
   #
   # This is the configuration file for the LDAP nameservice
   # switch library and the LDAP PAM module.
   #
   # PADL Software
   # http://www.padl.com
   #
   #
   # Your LDAP server. Must be resolvable without using LDAP.
   # Multiple hosts may be specified, each separated by a 
   # space. How long nss_ldap takes to failover depends on
   # whether your LDAP client library supports configurable
   # network or connect timeouts (see bind_timelimit).
   #host 127.0.0.1
   #
   # The distinguished name of the search base.
   base dc=midominio,dc=com,dc=ar 
   #    
   # Another way to specify your LDAP server is to provide an
   uri ldap://10.200.0.14/
   # Unix Domain Sockets to connect to a local LDAP Server.
   #uri ldap://127.0.0.1/
   #uri ldaps://127.0.0.1/   
   #uri ldapi://%2fvar%2frun%2fldapi_sock/
   # Note: %2f encodes the '/' used as directory separator
   #
   # The LDAP version to use (defaults to 3
   # if supported by client library)
   ldap_version 3
   #
   # The distinguished name to bind to the server with.
   # Optional: default is to bind anonymously.
   # Please do not put double quotes around it as they
   # would be included literally.
   #binddn cn=proxyuser,dc=padl,dc=com
   #
   # The credentials to bind with. 
   # Optional: default is no credential.
   #bindpw secret
   #
   # The distinguished name to bind to the server with
   # if the effective user ID is root. Password is
   # stored in /etc/libnss-ldap.secret (mode 600)
   # Use 'echo -n "mypassword" > /etc/libnss-ldap.secret' instead
   # of an editor to create the file.
   rootbinddn cn=admin,dc=midominio,dc=com,dc=ar
   #
   # The port.
   # Optional: default is 389.
   #port 389
   #
   # The search scope.
   #scope sub
   #scope one
   #scope base
   #
   # Search timelimit
   timelimit 30
   #
   # Bind/connect timelimit
   bind_timelimit 30
   #
   # Reconnect policy:
   #  hard_open: reconnect to DSA with exponential backoff if
   #             opening connection failed
   #  hard_init: reconnect to DSA with exponential backoff if
   #             initializing connection failed
   #  hard:      alias for hard_open
   #  soft:      return immediately on server failure
   #bind_policy hard
   #
   # Connection policy:
   #  persist:   DSA connections are kept open (default)
   #  oneshot:   DSA connections destroyed after request
   #nss_connect_policy persist
   #
   # Idle timelimit; client will close connections
   # (nss_ldap only) if the server has not been contacted
   # for the number of seconds specified below.
   #idle_timelimit 3600
   #
   # Use paged rseults
   #nss_paged_results yes
   #
   # Pagesize: when paged results enable, used to set the
   # pagesize to a custom value
   #pagesize 1000
   #
   # Filter to AND with uid=%s
   #pam_filter objectclass=account
   #
   # The user ID attribute (defaults to uid)
   #pam_login_attribute uid
   #
   # Search the root DSE for the password policy (works
   # with Netscape Directory Server)
   pam_lookup_policy yes
   #
   # Check the 'host' attribute for access control
   # Default is no; if set to yes, and user has no
   # value for the host attribute, and pam_ldap is
   # configured for account management (authorization)
   # then the user will not be allowed to login.
   #pam_check_host_attr yes
   #
   # Check the 'authorizedService' attribute for access
   # control
   # Default is no; if set to yes, and the user has no
   # value for the authorizedService attribute, and
   # pam_ldap is configured for account management
   # (authorization) then the user will not be allowed
   # to login.
   #pam_check_service_attr yes
   #
   # Group to enforce membership of
   #pam_groupdn cn=PAM,ou=Groups,dc=padl,dc=com
   #
   # Group member attribute
   #pam_member_attribute uniquemember
   #
   # Specify a minium or maximum UID number allowed
   #pam_min_uid 0
   #pam_max_uid 0
   #
   # Template login attribute, default template user
   # (can be overriden by value of former attribute
   # in user's entry)
   #pam_login_attribute userPrincipalName
   #pam_template_login_attribute uid
   #pam_template_login nobody
   #
   # HEADS UP: the pam_crypt, pam_nds_passwd,
   # and pam_ad_passwd options are no
   # longer supported.
   #
   # Do not hash the password at all; presume
   # the directory server will do it, if
   # necessary. This is the default.
   pam_password clear
   #
   # Hash password locally; required for University of
   # Michigan LDAP server, and works with Netscape
   # Directory Server if you're using the UNIX-Crypt
   # hash mechanism and not using the NT Synchronization
   # service. 
   #pam_password crypt
   #
   # Remove old password first, then update in
   # cleartext. Necessary for use with Novell
   # Directory Services (NDS)
   #pam_password nds
   #
   # RACF is an alias for the above. For use with
   # IBM RACF
   #pam_password racf
   # 
   # Update Active Directory password, by
   # creating Unicode password and updating
   # unicodePwd attribute.
   #pam_password ad
   #
   # Use the OpenLDAP password change
   # extended operation to update the password.
   #pam_password exop
   #
   # Redirect users to a URL or somesuch on password
   # changes.
   #pam_password_prohibit_message Please visit http://internal to change your password.
   #
   # Use backlinks for answering initgroups()
   #nss_initgroups backlink
   #
   # Enable support for RFC2307bis (distinguished names in group
   # members)
   #nss_schema rfc2307bis
   #
   # RFC2307bis naming contexts
   # Syntax:
   # nss_base_XXX		base?scope?filter
   # where scope is {base,one,sub}
   # and filter is a filter to be &'d with the
   # default filter.
   # You can omit the suffix eg:
   # nss_base_passwd	ou=People,
   # to append the default base DN but this
   # may incur a small performance impact.
   nss_base_passwd dc=midominio,dc=com,dc=ar?sub
   nss_base_shadow dc=midominio,dc=com,dc=ar?sub
   nss_base_group          ou=grupos,dc=midominio,dc=com,dc=ar?sub
   #nss_base_shadow	ou=People,dc=padl,dc=com?one
   #nss_base_group		ou=Group,dc=padl,dc=com?one
   #nss_base_hosts		ou=Hosts,dc=padl,dc=com?one
   #nss_base_services	        ou=Services,dc=padl,dc=com?one
   #nss_base_networks	        ou=Networks,dc=padl,dc=com?one
   #nss_base_protocols	        ou=Protocols,dc=padl,dc=com?one
   #nss_base_rpc		ou=Rpc,dc=padl,dc=com?one
   #nss_base_ethers	        ou=Ethers,dc=padl,dc=com?one
   #nss_base_netmasks	        ou=Networks,dc=padl,dc=com?ne
   #nss_base_bootparams	ou=Ethers,dc=padl,dc=com?one
   #nss_base_aliases	        ou=Aliases,dc=padl,dc=com?one
   #nss_base_netgroup	        ou=Netgroup,dc=padl,dc=com?one
   #
   # attribute/objectclass mapping
   # Syntax:
   #nss_map_attribute	        rfc2307attribute	mapped_attribute
   #nss_map_objectclass	rfc2307objectclass	mapped_objectclass
   #
   # configure --enable-nds is no longer supported.
   # NDS mappings
   #nss_map_attribute uniqueMember member
   #
   # Services for UNIX 3.5 mappings
   #nss_map_objectclass posixAccount User
   #nss_map_objectclass shadowAccount User
   #nss_map_attribute uid msSFU30Name
   #nss_map_attribute uniqueMember msSFU30PosixMember
   #nss_map_attribute userPassword msSFU30Password
   #nss_map_attribute homeDirectory msSFU30HomeDirectory
   #nss_map_attribute homeDirectory msSFUHomeDirectory
   #nss_map_objectclass posixGroup Group
   #pam_login_attribute msSFU30Name
   #pam_filter objectclass=User
   #pam_password ad
   #
   # configure --enable-mssfu-schema is no longer supported.
   # Services for UNIX 2.0 mappings
   #nss_map_objectclass posixAccount User
   #nss_map_objectclass shadowAccount user
   #nss_map_attribute uid msSFUName
   #nss_map_attribute uniqueMember posixMember
   #nss_map_attribute userPassword msSFUPassword
   #nss_map_attribute homeDirectory msSFUHomeDirectory
   #nss_map_attribute shadowLastChange pwdLastSet
   #nss_map_objectclass posixGroup Group
   #nss_map_attribute cn msSFUName
   #pam_login_attribute msSFUName
   #pam_filter objectclass=User
   #pam_password ad
   #
   # RFC 2307 (AD) mappings
   #nss_map_objectclass posixAccount user
   #nss_map_objectclass shadowAccount user
   #nss_map_attribute uid sAMAccountName
   #nss_map_attribute homeDirectory unixHomeDirectory
   #nss_map_attribute shadowLastChange pwdLastSet
   #nss_map_objectclass posixGroup group
   #nss_map_attribute uniqueMember member
   #pam_login_attribute sAMAccountName
   #pam_filter objectclass=User
   #pam_password ad
   #
   # configure --enable-authpassword is no longer supported
   # AuthPassword mappings
   #nss_map_attribute userPassword authPassword
   #
   # AIX SecureWay mappings
   #nss_map_objectclass posixAccount aixAccount
   #nss_base_passwd ou=aixaccount,?one
   #nss_map_attribute uid userName
   #nss_map_attribute gidNumber gid
   #nss_map_attribute uidNumber uid
   #nss_map_attribute userPassword passwordChar
   #nss_map_objectclass posixGroup aixAccessGroup
   #nss_base_group ou=aixgroup,?one
   #nss_map_attribute cn groupName
   #nss_map_attribute uniqueMember member
   #pam_login_attribute userName
   #pam_filter objectclass=aixAccount
   #pam_password clear
   #
   # For pre-RFC2307bis automount schema
   #nss_map_objectclass automountMap nisMap
   #nss_map_attribute automountMapName nisMapName
   #nss_map_objectclass automount nisObject
   #nss_map_attribute automountKey cn
   #nss_map_attribute automountInformation nisMapEntry
   #
   # Netscape SDK LDAPS
   #ssl on
   #
   # Netscape SDK SSL options
   #sslpath /etc/ssl/certs
   #
   # OpenLDAP SSL mechanism
   # start_tls mechanism uses the normal LDAP port, LDAPS typically 636
   #ssl start_tls
   #ssl on
   #
   # OpenLDAP SSL options
   # Require and verify server certificate (yes/no)
   # Default is to use libldap's default behavior, which can be configured in
   # /etc/openldap/ldap.conf using the TLS_REQCERT setting.  The default for
   # OpenLDAP 2.0 and earlier is "no", for 2.1 and later is "yes".
   #tls_checkpeer yes
   #
   # CA certificates for server certificate verification
   # At least one of these are required if tls_checkpeer is "yes"
   #tls_cacertfile /etc/ssl/ca.cert
   #tls_cacertdir /etc/ssl/certs
   #
   # Seed the PRNG if /dev/urandom is not provided 
   #tls_randfile /var/run/egd-pool
   #
   # SSL cipher suite
   # See man ciphers for syntax
   #tls_ciphers TLSv1
   #
   # Client certificate and key
   # Use these, if your server requires client authentication.
   #tls_cert
   #tls_key
   #
   # Disable SASL security layers. This is needed for AD.
   #sasl_secprops maxssf=0 
   # 
   # Override the default Kerberos ticket cache location.
   #krb5_ccname FILE:/etc/.ldapcache
   #

Tras el carácter “?”, se puede poner one (por defecto), base o sub; yo he empleado sub para que también compruebe los usuarios y contraseñas creados colgando de la unidad organizativa “usuarios” -es decir en las unidades organizativas contabilidad y desarrollo-.

Configuración de Servicios PAM

Nuestro sistema ya estaría preparado para autentificarse por LDAP. Editando los archivos que hay en la carpeta /etc/pam.d, podemos configurar la forma en la que se autentifica cada uno de los servicios que requieren autentificación.

Para no tener que configurar de cada uno de los servicios, existen unos archivos comunes cuyo nombre empieza por common que afectan a la mayoría de ellos y sus archivos de configuración los referencian mediante una línea @include a los archivos comunes causando el mismo el efecto que si el contenido de los archivos comunes estuviera copiado en el lugar de la línea @include. Los archivos comunes son:

   * /etc/pam.d/common-auth (para autentificarse)
   * /etc/pam.d/common-account (para disponer de una cuenta)
   * /etc/pam.d/common-session (para poder iniciar sesion)
   * /etc/pam.d/common-password (para poder cambiar password)

Estos archivos contienen una línea que hace referencia a la librería pam_unix.so que corresponde a la autentificación contra los archivos UNIX. Para que los servicios de nuestro sistema utilicen primero las librerías pam_ldap.so para autentificar al usuario, debemos añadir la línea correspondiente a pam_ldap.so por encima de la línea correspondiente a la librería pam_unix.so en los archivos common. Así, auntentificará primero contra el servidor LDAP, y si la autentificación falla, probará despues con los archivos UNIX.

Configuración archivo common-auth

Para que los servicios de nuestro sistema utilicen las librerías pam-ldap para autentificar al usuario, debemos añadir en el archivo /etc/pam.d/common-auth la siguiente línea:

// Añadir en /etc/pam.d/common-auth encima de la línea pam_unix.so

   auth sufficient pam_ldap.so


Además de ello, hemos de modificar la línea -añadiendo al final use_first_pass:

auth required pam_unix.so use_first_pass

// en caso contrario cuando hagamos su para un usuario dado de alta en ldap nos pedirá la contraseña dos veces

Configuración archivo common-account

Para permitir que los servicios de nuestro sistema comprueben la cuenta del usuario mediante las librerías pam-ldap, debemos añadir en el archivo /etc/pam.d/common-account la siguiente línea:

// Añadir en /etc/pam.d/common-account encima de la línea pam_unix.so

   account sufficient pam_ldap.so nullok_secure
   session required        pam_mkhomedir.so        skel=/etc/skel/ umask=077 (Este parametro hay que agregarlo para que cree la home del usuario si no existe.)
Configuración archivo common-session

Para permitir que los servicios de nuestro sistema obtengan los parámetros de la sesión de usuario mediante las librerías pam-ldap, debemos añadir en el archivo /etc/pam.d/common-session la siguiente línea:

// Añadir en /etc/pam.d/common-session encima de la línea pam_unix.so

   session sufficient pam_ldap.so


Configuración archivo common-password

Para permitir que los servicios de nuestro sistema puedan modificar la contraseña del usuario mediante las librerías pam-ldap, debemos añadir en el archivo /etc/pam.d/common-password la siguiente línea:

// Añadir en /etc/pam.d/common-password encima de la línea pam_unix.so

   password sufficient pam_ldap.so


Configuración archivo gdm-autologin

Este archivo debe midificarse para que los usuarios de puedan logear desde el modo grafico.

// verificar en /etc/pam.d/gdm-autologin, que se encuentren estas cuatro lineas ademas de otros parametros

@include common-auth
@include common-account
@include common-session
@include common-password