Let private generation use Account class
authorPeter Palfrader <peter@palfrader.org>
Mon, 2 Aug 2010 20:23:53 +0000 (20:23 +0000)
committerPeter Palfrader <peter@palfrader.org>
Mon, 2 Aug 2010 20:23:53 +0000 (20:23 +0000)
UDLdap.py
ud-generate

index 9f8a0fd..74313b2 100644 (file)
--- a/UDLdap.py
+++ b/UDLdap.py
@@ -66,6 +66,9 @@ class Account:
     def numkeys(self):
         return len(self['keyFingerPrint'])
 
+    def is_active_user(self):
+        return self['accountStatus'] == 'active' and self.numkeys() != 0
+
     def latitude_dec(self, anonymized=False):
         return userdir_ldap.DecDegree(self['latitude'], anonymized)
     def longitude_dec(self, anonymized=False):
index 303f9f5..1a40f67 100755 (executable)
@@ -608,15 +608,13 @@ def GenPrivate(File):
      
       # Write out the position for each user
       for x in DebianDDUsers:
-         if x[1].has_key("privateSub") == 0:
+         a = UDLdap.Account(x[0], x[1])
+         if not a.is_active_user():
             continue
-     
-         # If the account has no PGP key, do not write it
-         if x[1].has_key("keyFingerPrint") == 0:
+         if not 'privateSub' in a:
             continue
-     
          try:
-            Line = "%s"%(GetAttr(x, "privateSub"))
+            Line = "%s"%(a['privateSub'])
             Line = Sanitize(Line) + "\n"
             F.write(Line)
          except: