From ae61f98ab59bf0ebeb8e861bd6cc0d4a167febc6 Mon Sep 17 00:00:00 2001 From: Sven Slootweg Date: Sun, 27 May 2012 13:39:15 +0200 Subject: [PATCH] Actually parse and write HTML and plaintext files --- render | 38 +++++++++++++++++++++++++++++++++++--- templates/message.html | 2 ++ 2 files changed, 37 insertions(+), 3 deletions(-) diff --git a/render b/render index d34131b..3115ebe 100755 --- a/render +++ b/render @@ -4,12 +4,15 @@ import os, argparse, hashlib, sqlite3, time parser = argparse.ArgumentParser(description='Renders static HTML pages and indexes from an SQLite database of emails and an attachment folder.') -parser.add_argument('-o', dest='output_dir', action='store', default='render', +parser.add_argument('-o', dest='output_dir', action='store', default='rendered_files', help='path of the directory where rendered files should be stored') parser.add_argument('-t', dest='template_dir', action='store', default='templates', help='path where the template files are') +parser.add_argument('-i', dest='title', action='store', default='Inbox', + help='title for the rendered pages') + parser.add_argument('-d', dest='database', action='store', default='emails.db', help='path of the database that should be used to render the e-mail files') @@ -30,8 +33,37 @@ cursor = database.cursor() # Load templates template_message = open('%s/message.html' % options['template_dir']).read() +# Create output directory if necessary +try: + os.makedirs(options['output_dir']) +except OSError: + pass + for message in cursor.execute("SELECT * FROM emails"): message_id, sender, recipient, subject, timestamp, textbody, htmlbody, sha1_hash = message - generated = template_message % {'subject': subject, 'date': timestamp, 'from': sender, 'to': recipient, 'body': textbody, 'title': "admin@cryto.net", 'version': "Plaintext version"} - print generated + + versions = {} + + if textbody != "": + available_text = True + versions['Plaintext'] = '%s_text.html' % sha1_hash + + if htmlbody != "": + available_html = True + versions['HTML'] = '%s_html.html' % sha1_hash + + version_list = "".join(['%s' % (value, key) for key, value in versions.viewitems()]) + + if available_text: + # Text version + body = "
%s
" % textbody + generated = template_message % {'subject': subject, 'date': timestamp, 'from': sender, 'to': recipient, 'body': body, 'title': options['title'], 'version': "Plaintext version", 'index': "../index.html", 'versions': version_list} + open('%s/%s_text.html' % (options['output_dir'], sha1_hash), 'w').write(generated.encode('UTF-8')) + + if available_html: + # HTML version + body = htmlbody + generated = template_message % {'subject': subject, 'date': timestamp, 'from': sender, 'to': recipient, 'body': body, 'title': options['title'], 'version': "HTML version", 'index': "../index.html", 'versions': version_list} + open('%s/%s_html.html' % (options['output_dir'], sha1_hash), 'w').write(generated.encode('UTF-8')) + exit(1) diff --git a/templates/message.html b/templates/message.html index 4e3293e..09161f2 100644 --- a/templates/message.html +++ b/templates/message.html @@ -11,6 +11,8 @@

%(subject)s

%(version)s

+ %(versions)s +
From: