From 65a87133ac45ecc72c0b41a8d88c8d7b7fa7b15b Mon Sep 17 00:00:00 2001 From: Mark Hymers Date: Wed, 14 May 2008 19:55:18 +0100 Subject: [PATCH] reimport initial multiple ssh keys code which bzr kindly threw away after merging on my old branch --- ud-generate | 70 ++++++++++++++++++++++++++++++++++------------- ud-replicate | 9 ++++++ userdir-ldap.conf | 2 ++ userdir_ldap.py | 4 +++ 4 files changed, 66 insertions(+), 19 deletions(-) diff --git a/ud-generate b/ud-generate index d2f00ab..a0dc9a4 100755 --- a/ud-generate +++ b/ud-generate @@ -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"; @@ -200,16 +206,41 @@ def GenSSHShadow(l,File): 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): @@ -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"); @@ -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") diff --git a/ud-replicate b/ud-replicate index 655b263..0f98f8b 100755 --- a/ud-replicate +++ b/ud-replicate @@ -68,6 +68,15 @@ done ln -sf `pwd -P`/ssh-rsa-shadow /etc/ssh ln -sf `pwd -P`/ssh_known_hosts /etc/ssh +find $HOST -name "ssh-rsa-shadow-*" -type f | while read f +do + user=$(echo $f | sed s@.*-@@) + id ${user} 2>/dev/null >/dev/null + if [ $? -eq 0 ]; then + chown $user $f + fi +done + if [ -x /usr/bin/dchroot ]; then CHROOTS=`dchroot --listpaths` for c in $CHROOTS; do diff --git a/userdir-ldap.conf b/userdir-ldap.conf index d3a37bb..98a4c28 100644 --- a/userdir-ldap.conf +++ b/userdir-ldap.conf @@ -36,6 +36,8 @@ defaultgid = 800; # For the output generator generateconf = "/etc/userdir-ldap/generate.conf" generatedir = "/var/cache/userdir-ldap/hosts/"; +singlesshfile = True +multiplesshfiles = False passdir = "/etc/userdir-ldap/"; # GPG Things diff --git a/userdir_ldap.py b/userdir_ldap.py index 0ef1099..539dbae 100644 --- a/userdir_ldap.py +++ b/userdir_ldap.py @@ -41,6 +41,10 @@ PassDir = ConfModule.passdir; Ech_ErrorLog = ConfModule.ech_errorlog; Ech_MainLog = ConfModule.ech_mainlog; +# For backwards compatibility, we default to the old behaviour +MultipleSSHFiles = getattr(ConfModule, 'multiplesshfiles', False) +SingleSSHFile = getattr(ConfModule, 'singlesshfile', True) + # Break up the keyring list userdir_gpg.SetKeyrings(ConfModule.keyrings.split(":")) -- 2.20.1