From dab1d03d81c538966d03fb9318a4588a9e803b44 Mon Sep 17 00:00:00 2001 From: Sol Jerome Date: Sat, 24 Mar 2012 11:20:07 -0500 Subject: Allow to run directly from a git checkout (#1037) Signed-off-by: Sol Jerome --- src/lib/Bcfg2/Server/Reports/nisauth.py | 44 +++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 src/lib/Bcfg2/Server/Reports/nisauth.py (limited to 'src/lib/Bcfg2/Server/Reports/nisauth.py') diff --git a/src/lib/Bcfg2/Server/Reports/nisauth.py b/src/lib/Bcfg2/Server/Reports/nisauth.py new file mode 100644 index 000000000..b3e37113b --- /dev/null +++ b/src/lib/Bcfg2/Server/Reports/nisauth.py @@ -0,0 +1,44 @@ +import crypt +import nis +from Bcfg2.Server.Reports.settings import AUTHORIZED_GROUP + +"""Checks with NIS to see if the current user is in the support group""" + + +class NISAUTHError(Exception): + """NISAUTHError is raised when somehting goes boom.""" + pass + + +class nisauth(object): + group_test = False + samAcctName = None + distinguishedName = None + sAMAccountName = None + telephoneNumber = None + title = None + memberOf = None + department = None # this will be a list + mail = None + extensionAttribute1 = None # badgenumber + badge_no = None + uid = None + + def __init__(self, login, passwd=None): + """get user profile from NIS""" + try: + p = nis.match(login, 'passwd.byname').split(":") + print(p) + except: + raise NISAUTHError('username') + # check user password using crypt and 2 character salt from passwd file + if p[1] == crypt.crypt(passwd, p[1][:2]): + # check to see if user is in valid support groups + # will have to include these groups in a settings file eventually + if not login in nis.match(AUTHORIZED_GROUP, + 'group.byname').split(':')[-1].split(','): + raise NISAUTHError('group') + self.uid = p[2] + print(self.uid) + else: + raise NISAUTHError('password') -- cgit v1.2.3-1-g7c22