commit 96948a01265142e39022a704dfb228ab3dbb6696 Author: Christian Fromme kaner@strace.org Date: Wed Oct 19 21:43:24 2011 +0200
Send out the short user manual together with GetTor packages. Fixes #4163. --- lib/gettor/packages.py | 12 ++++++++++++ lib/gettor/responses.py | 26 ++++++++++++++++++++++++++ lib/gettor/utils.py | 3 +++ 3 files changed, 41 insertions(+), 0 deletions(-)
diff --git a/lib/gettor/packages.py b/lib/gettor/packages.py index cbfddb4..0f205c1 100644 --- a/lib/gettor/packages.py +++ b/lib/gettor/packages.py @@ -11,6 +11,7 @@ import gettor.config import gettor.utils import re import glob +import shutil
# Stolen from Mike's TorCtl: class RouterVersion: @@ -60,6 +61,7 @@ class Packages: self.packageList = {} self.distDir = os.path.join(config.BASEDIR, "dist") self.packDir = os.path.join(config.BASEDIR, "packages") + self.docDir = os.path.join(config.BASEDIR, "doc") self.initRsync(config.RSYNC_MIRROR, silent) self.packageList = config.PACKAGES
@@ -194,6 +196,16 @@ class Packages: logging.debug("All split files for package %s created." % pack) return True
+ def copyManuals(self): + """Copy the short user manuals to their destination directory + """ + manualDir = os.path.join(self.distDir, "manual") + gettor.utils.createDir(self.docDir) + for f in glob.glob(os.path.join(manualDir, "*.xhtml")): + copyTo = os.path.join(self.docDir, os.path.basename(f)) + shutil.copyfile(f, copyTo) + logging.debug("%s copied." % f) + def getPart(self, fileName): """Helper function: Extract the `partXX' part of the file name. """ diff --git a/lib/gettor/responses.py b/lib/gettor/responses.py index 6a5adf7..94d8400 100644 --- a/lib/gettor/responses.py +++ b/lib/gettor/responses.py @@ -260,6 +260,7 @@ class Response: f = os.path.join(self.config.BASEDIR, "packages", pack + ".z") txt = getPackageMsg(self.t) msg = self.makeMsg(txt, to, fileName=f) + msg = self.addUserManual(msg, self.reqInfo['locale']) try: status = self.sendEmail(to, msg) except: @@ -431,6 +432,31 @@ class Response:
return message
+ def addUserManual(self, message, lang="en"): + """Add the short user manual to an existing message. + """ + docDir = os.path.join(self.config.BASEDIR, "doc") + mName = "short-user-manual_" + lang + ".xhtml" + docName = os.path.join(docDir, mName) + if not os.access(docName, os.R_OK): + # Fall back to english if a certain locale isn't + # available + mName = "short-user-manual_en.xhtml" + docName = os.path.join(docDir, mName) + if os.access(docName, os.R_OK): + filePart = MIMEBase("application", "xhtml") + fp = open(docName, 'rb') + filePart.set_payload(fp.read()) + fp.close() + encoders.encode_base64(filePart) + # Add file part + filePart.add_header('Content-Disposition', 'attachment', filename=mName) + message.attach(filePart) + else: + logging.error("Could not open manual file %d" % docName) + + return message + def sendEmail(self, sendTo, message, smtpserver="localhost:25"): """Send out message via STMP. If an error happens, be verbose about the reason diff --git a/lib/gettor/utils.py b/lib/gettor/utils.py index c06e40f..6ac754b 100644 --- a/lib/gettor/utils.py +++ b/lib/gettor/utils.py @@ -85,6 +85,9 @@ def prepPackages(conf): if not packs.buildPackages(): return False
+ # Copy the short user manual + packs.copyManuals() + logging.debug("Building packages done.") return True