lists.arthurdejong.org
RSS feed

nss-pam-ldapd commit: r1381 - nss-pam-ldapd/pynslcd

[Date Prev][Date Next] [Thread Prev][Thread Next]

nss-pam-ldapd commit: r1381 - nss-pam-ldapd/pynslcd



Author: arthur
Date: Sun Mar  6 16:58:14 2011
New Revision: 1381
URL: http://arthurdejong.org/viewvc/nss-pam-ldapd?view=rev&revision=1381

Log:
implement module for netgroup lookups

Added:
   nss-pam-ldapd/pynslcd/netgroup.py
Modified:
   nss-pam-ldapd/pynslcd/Makefile.am
   nss-pam-ldapd/pynslcd/pynslcd.py

Modified: nss-pam-ldapd/pynslcd/Makefile.am
==============================================================================
--- nss-pam-ldapd/pynslcd/Makefile.am   Sun Mar  6 16:09:20 2011        (r1380)
+++ nss-pam-ldapd/pynslcd/Makefile.am   Sun Mar  6 16:58:14 2011        (r1381)
@@ -20,8 +20,8 @@
 pynslcddir = $(datadir)/pynslcd
 
 pynslcd_PYTHON = pynslcd.py cfg.py common.py tio.py mypidfile.py \
-                 alias.py ether.py group.py host.py network.py pam.py \
-                 passwd.py shadow.py
+                 alias.py ether.py group.py host.py netgroup.py network.py \
+                 pam.py passwd.py shadow.py
 nodist_pynslcd_PYTHON = constants.py config.py
 CLEANFILES = $(nodist_pynslcd_PYTHON)
 

Added: nss-pam-ldapd/pynslcd/netgroup.py
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ nss-pam-ldapd/pynslcd/netgroup.py   Sun Mar  6 16:58:14 2011        (r1381)
@@ -0,0 +1,80 @@
+
+# netgroup.py - lookup functions for netgroups
+#
+# Copyright (C) 2011 Arthur de Jong
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+# 02110-1301 USA
+
+import constants
+import common
+
+import struct
+import ldap.filter
+import socket
+import re
+
+
+_netgroup_triple_re = 
re.compile(r'^\s*\(\s*(?P<host>.*)\s*,\s*(?P<user>.*)\s*,\s*(?P<domain>.*)\s*\)\s*$')
+
+
+class NetgroupRequest(common.Request):
+
+    filter = '(objectClass=nisNetgroup)'
+
+    attmap_cn                = 'cn'
+    attmap_nisNetgroupTriple = 'nisNetgroupTriple'
+    attmap_memberNisNetgroup = 'memberNisNetgroup'
+
+    attributes = ( 'cn', 'nisNetgroupTriple', 'memberNisNetgroup' )
+
+    def write(self, entry):
+        dn, attributes = entry
+        # get names and check against requested user name
+        names = attributes.get(self.attmap_cn, [])
+        if self.name:
+            if self.name not in names:
+                return
+            names = ( self.name, )
+        if not names:
+            print 'Error: entry %s does not contain %s value' % ( dn, 
self.attmap_cn)
+        # write the netgroup triples
+        for triple in attributes.get(self.attmap_nisNetgroupTriple, []):
+            m = _netgroup_triple_re.match(triple)
+            if not m:
+                print 'Warning: entry %s contains invalid %s value: %r' % ( 
dn, self.attmap_nisNetgroupTriple, triple)
+            else:
+                self.fp.write_int32(constants.NSLCD_RESULT_BEGIN)
+                self.fp.write_int32(constants.NSLCD_NETGROUP_TYPE_TRIPLE)
+                self.fp.write_string(m.group('host'))
+                self.fp.write_string(m.group('user'))
+                self.fp.write_string(m.group('domain'))
+        # write netgroup members
+        for member in attributes.get(self.attmap_memberNisNetgroup, []):
+            self.fp.write_int32(constants.NSLCD_RESULT_BEGIN)
+            self.fp.write_int32(constants.NSLCD_NETGROUP_TYPE_NETGROUP)
+            self.fp.write_string(member)
+
+
+class NetgroupByNameRequest(NetgroupRequest):
+
+    action = constants.NSLCD_ACTION_NETGROUP_BYNAME
+
+    def read_parameters(self):
+        self.name = self.fp.read_string()
+
+    def mk_filter(self):
+        return '(&%s(%s=%s))' % ( self.filter,
+                  self.attmap_cn, ldap.filter.escape_filter_chars(self.name) )

Modified: nss-pam-ldapd/pynslcd/pynslcd.py
==============================================================================
--- nss-pam-ldapd/pynslcd/pynslcd.py    Sun Mar  6 16:09:20 2011        (r1380)
+++ nss-pam-ldapd/pynslcd/pynslcd.py    Sun Mar  6 16:58:14 2011        (r1381)
@@ -142,6 +142,7 @@
 handlers.update(common.get_handlers('ether'))
 handlers.update(common.get_handlers('group'))
 handlers.update(common.get_handlers('host'))
+handlers.update(common.get_handlers('netgroup'))
 handlers.update(common.get_handlers('network'))
 handlers.update(common.get_handlers('pam'))
 handlers.update(common.get_handlers('passwd'))
-- 
To unsubscribe send an email to
nss-pam-ldapd-commits-unsubscribe@lists.arthurdejong.org or see
http://lists.arthurdejong.org/nss-pam-ldapd-commits