mirror of
https://github.com/cwinfo/powerdns-admin.git
synced 2025-01-07 19:05:39 +00:00
Add group-based security implementation for non-AD LDAP servers.
This commit is contained in:
parent
05944e8585
commit
5914c3cc86
@ -178,11 +178,16 @@ class User(db.Model):
|
|||||||
l.simple_bind_s(ldap_username, self.password)
|
l.simple_bind_s(ldap_username, self.password)
|
||||||
if LDAP_GROUP_SECURITY:
|
if LDAP_GROUP_SECURITY:
|
||||||
try:
|
try:
|
||||||
groupSearchFilter = "(&(objectcategory=group)(member=%s))" % ldap_username
|
if LDAP_TYPE == 'ldap':
|
||||||
|
uid = result[0][0][1]['uid'][0]
|
||||||
|
groupSearchFilter = "(&(objectClass=posixGroup)(memberUid=%s))" % uid
|
||||||
|
else:
|
||||||
|
groupSearchFilter = "(&(objectcategory=group)(member=%s))" % ldap_username
|
||||||
groups = self.ldap_search(groupSearchFilter, LDAP_SEARCH_BASE)
|
groups = self.ldap_search(groupSearchFilter, LDAP_SEARCH_BASE)
|
||||||
allowedlogin = False
|
allowedlogin = False
|
||||||
isadmin = False
|
isadmin = False
|
||||||
for group in groups:
|
for group in groups:
|
||||||
|
logging.debug(group)
|
||||||
if (group[0][0] == LDAP_ADMIN_GROUP):
|
if (group[0][0] == LDAP_ADMIN_GROUP):
|
||||||
allowedlogin = True
|
allowedlogin = True
|
||||||
isadmin = True
|
isadmin = True
|
||||||
@ -194,7 +199,7 @@ class User(db.Model):
|
|||||||
logging.error('User %s is not part of the "%s" or "%s" groups that allow access to PowerDNS-Admin' % (self.username,LDAP_ADMIN_GROUP,LDAP_USER_GROUP))
|
logging.error('User %s is not part of the "%s" or "%s" groups that allow access to PowerDNS-Admin' % (self.username,LDAP_ADMIN_GROUP,LDAP_USER_GROUP))
|
||||||
return False
|
return False
|
||||||
except:
|
except:
|
||||||
logging.error('LDAP group lookup for user %s has failed' % self.username)
|
logging.error('LDAP group lookup for user "%s" has failed' % self.username)
|
||||||
logging.info('User "%s" logged in successfully' % self.username)
|
logging.info('User "%s" logged in successfully' % self.username)
|
||||||
|
|
||||||
# create user if not exist in the db
|
# create user if not exist in the db
|
||||||
@ -227,7 +232,7 @@ class User(db.Model):
|
|||||||
self.set_admin(isadmin)
|
self.set_admin(isadmin)
|
||||||
return True
|
return True
|
||||||
except:
|
except:
|
||||||
logging.error('User "%s" input a wrong password(stage2)' % self.username)
|
logging.error('User "%s" input a wrong password' % self.username)
|
||||||
return False
|
return False
|
||||||
else:
|
else:
|
||||||
logging.error('Unsupported authentication method')
|
logging.error('Unsupported authentication method')
|
||||||
|
Loading…
Reference in New Issue
Block a user