From: Mark Hymers Date: Wed, 14 May 2008 19:37:13 +0000 (+0100) Subject: merge from debian branch X-Git-Tag: userdir-ldap-0.3.24~5^2^2~8 X-Git-Url: https://git.adam-barratt.org.uk/?a=commitdiff_plain;h=fb2a20c640baae70d3977c0a1b66c9d81be206dd;hp=-c;p=mirror%2Fuserdir-ldap.git merge from debian branch --- fb2a20c640baae70d3977c0a1b66c9d81be206dd diff --combined ud-generate index a0dc9a4,f3ffc4c..6870ed9 --- a/ud-generate +++ b/ud-generate @@@ -177,20 -177,14 +177,20 @@@ def GenShadow(l,File) Done(File,None,F); # Generate the shadow list -def GenSSHShadow(l,File): - F = None; - try: - OldMask = os.umask(0077); - F = open(File + ".tmp","w",0600); - os.umask(OldMask); - +def GenSSHShadow(l,masterFileName): # Fetch all the users + files = [] + # Depending on config, we write out either a single file, + # multiple files, or both + if SingleSSHFile: + try: + OldMask = os.umask(0077); + masterFile = open(masterFileName + ".tmp","w",0600); + os.umask(OldMask); + except IOError: + Die(masterFileName,masterFile,None) + raise + global PasswdAttrs; if PasswdAttrs == None: raise "No Users"; @@@ -206,41 -200,16 +206,41 @@@ if x[1].has_key("uidNumber") == 0 or \ x[1].has_key("sshRSAAuthKey") == 0: continue; - for I in x[1]["sshRSAAuthKey"]: - User = GetAttr(x,"uid"); - Line = "%s: %s" %(User,I); - Line = Sanitize(Line) + "\n"; - F.write(Line); - # Oops, something unspeakable happened. - except: - Die(File,F,None); - raise; - Done(File,F,None); + User = GetAttr(x,"uid"); + F = None; + + try: + if MultipleSSHFiles: + OldMask = os.umask(0077); + File = masterFileName + "-" + User + F = open(File + ".tmp","w",0600); + os.umask(OldMask); + + for I in x[1]["sshRSAAuthKey"]: + if MultipleSSHFiles: + MultipleLine = "%s" % I + MultipleLine = Sanitize(MultipleLine) + "\n" + F.write(MultipleLine) + if SingleSSHFile: + SingleLine = "%s: %s" % (User, I) + SingleLine = Sanitize(SingleLine) + "\n" + masterFile.write(SingleLine) + + if MultipleSSHFiles: + Done(File,F,None); + files.append(os.path.basename(File)) + + # Oops, something unspeakable happened. + except IOError: + Die(File,F,None) + Die(masterFileName,masterFile,None) + raise; + + if SingleSSHFile: + Done(masterFileName,masterFile,None) + files.append(os.path.basename(masterFileName)) + + return files # Generate the group list def GenGroup(l,File): @@@ -765,7 -734,7 +765,7 @@@ def GenSSHKnown(l,File) else: IPAdresses += [addr[1]] for I in x[1]["sshRSAHostKey"]: - Line = "%s,%s %s" %(",".join(HostNames + IPAdresses), I); + Line = "%s %s" %(",".join(HostNames + IPAdresses), I); Line = Sanitize(Line) + "\n"; F.write(Line); # Oops, something unspeakable happened. @@@ -848,7 -817,7 +848,7 @@@ else # Generate global things GlobalDir = GenerateDir+"/"; -GenSSHShadow(l,GlobalDir+"ssh-rsa-shadow"); +SSHFiles = GenSSHShadow(l,GlobalDir+"ssh-rsa-shadow"); GenAllForward(l,GlobalDir+"mail-forward.cdb"); GenMarkers(l,GlobalDir+"markers"); GenPrivate(l,GlobalDir+"debian-private"); @@@ -897,8 -866,7 +897,8 @@@ while(1) Allowed = None CurrentHost = Split[0]; - DoLink(GlobalDir,OutDir,"ssh-rsa-shadow"); + for file in SSHFiles: + DoLink(GlobalDir,OutDir,file); DoLink(GlobalDir,OutDir,"debianhosts"); DoLink(GlobalDir,OutDir,"ssh_known_hosts"); DoLink(GlobalDir,OutDir,"disabled-accounts")