summaryrefslogtreecommitdiffstats
path: root/reports/brpt/nisauth.py
diff options
context:
space:
mode:
authorKen Raffenetti <raffenet@mcs.anl.gov>2006-11-03 16:52:42 +0000
committerKen Raffenetti <raffenet@mcs.anl.gov>2006-11-03 16:52:42 +0000
commit23c1f2cc6be9926fdfe85e37869ef88f84b9200e (patch)
tree54630fb2d24346f1e60f00d254e7a73a2ad83833 /reports/brpt/nisauth.py
parent6c3e429e7d60ac38e4151f2713511c0f6281652e (diff)
downloadbcfg2-23c1f2cc6be9926fdfe85e37869ef88f84b9200e.tar.gz
bcfg2-23c1f2cc6be9926fdfe85e37869ef88f84b9200e.tar.bz2
bcfg2-23c1f2cc6be9926fdfe85e37869ef88f84b9200e.zip
added capability for authentication in reports
git-svn-id: https://svn.mcs.anl.gov/repos/bcfg/trunk/bcfg2@2473 ce84e21b-d406-0410-9b95-82705330c041
Diffstat (limited to 'reports/brpt/nisauth.py')
-rw-r--r--reports/brpt/nisauth.py43
1 files changed, 43 insertions, 0 deletions
diff --git a/reports/brpt/nisauth.py b/reports/brpt/nisauth.py
new file mode 100644
index 000000000..e9a954cd8
--- /dev/null
+++ b/reports/brpt/nisauth.py
@@ -0,0 +1,43 @@
+import os
+import crypt, nis
+import brpt.settings import AUTHORIZED_GROUP
+
+"""Checks with NIS to see if the current user is in the support group"""
+
+__revision__ = "$Revision: $"
+
+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')