Si bien la respuesta aceptada de hecho muestra una forma adecuada de vincularse a un servidor LDAP, creo que no respondió la pregunta de manera integral. Esto es lo que terminé implementando para tomar el correo y el departamento de un usuario. Esto de alguna manera combina los atributos requeridos de la pregunta original.
l = ldap.initialize('ldap://ldap.myserver.com:389')
binddn = "cn=myUserName,ou=GenericID,dc=my,dc=company,dc=com"
pw = "myPassword"
basedn = "ou=UserUnits,dc=my,dc=company,dc=com"
searchFilter = "(&(gidNumber=123456)(objectClass=posixAccount))"
searchAttribute = ["mail","department"]
#this will scope the entire subtree under UserUnits
searchScope = ldap.SCOPE_SUBTREE
#Bind to the server
try:
l.protocol_version = ldap.VERSION3
l.simple_bind_s(binddn, pw)
except ldap.INVALID_CREDENTIALS:
print "Your username or password is incorrect."
sys.exit(0)
except ldap.LDAPError, e:
if type(e.message) == dict and e.message.has_key('desc'):
print e.message['desc']
else:
print e
sys.exit(0)
try:
ldap_result_id = l.search(basedn, searchScope, searchFilter, searchAttribute)
result_set = []
while 1:
result_type, result_data = l.result(ldap_result_id, 0)
if (result_data == []):
break
else:
## if you are expecting multiple results you can append them
## otherwise you can just wait until the initial result and break out
if result_type == ldap.RES_SEARCH_ENTRY:
result_set.append(result_data)
print result_set
except ldap.LDAPError, e:
print e
l.unbind_s()
Necesita 'apt-get install python-ldap' antes de que esto funcione. – 9000
¿Estoy loco, o esto no responde la pregunta? Está preguntando cómo ejecutar una consulta, y le estás mostrando cómo enlazar. –
@mehasse: El ejemplo fue diseñado para mostrar el uso común del módulo ldap, que creo que sí. Si intenta hacer una consulta, puede usar el método .search en el objeto ldap. – Claris