Created
September 24, 2018 08:04
-
-
Save grenade/3c791e47a293aee9811089fa3bf777cb to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import ldap | |
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() |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment