|
|
@ -1,6 +1,6 @@
|
|
|
|
#!/usr/bin/python
|
|
|
|
#!/usr/bin/python
|
|
|
|
|
|
|
|
|
|
|
|
import os, argparse, hashlib, sqlite3, time, shutil, cgi, re
|
|
|
|
import os, argparse, hashlib, sqlite3, time, shutil, cgi, re, math
|
|
|
|
from datetime import datetime
|
|
|
|
from datetime import datetime
|
|
|
|
|
|
|
|
|
|
|
|
parser = argparse.ArgumentParser(description='Renders static HTML pages and indexes from an SQLite database of emails and an attachment folder.')
|
|
|
|
parser = argparse.ArgumentParser(description='Renders static HTML pages and indexes from an SQLite database of emails and an attachment folder.')
|
|
|
@ -30,6 +30,32 @@ def format_size(num):
|
|
|
|
num /= 1024.0
|
|
|
|
num /= 1024.0
|
|
|
|
return "%3.1f%s" % (num, 'TB')
|
|
|
|
return "%3.1f%s" % (num, 'TB')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def chunk(iterable, chunksize, fillvalue=None):
|
|
|
|
|
|
|
|
result = []
|
|
|
|
|
|
|
|
num_chunks = int(math.ceil(len(iterable) / (chunksize * 1.0)))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for i in xrange(0, num_chunks):
|
|
|
|
|
|
|
|
missing = (chunksize * (i + 1)) - len(iterable)
|
|
|
|
|
|
|
|
start = (chunksize * i)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if missing > 0:
|
|
|
|
|
|
|
|
end = len(iterable)
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
end = (chunksize * (i + 1))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result.append((iterable[start:end]))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return result
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def render_index(email_list, title, identifier):
|
|
|
|
|
|
|
|
new_list = []
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for message in email_list:
|
|
|
|
|
|
|
|
new_list.append((message[0], message[0]))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
new_list = chunk(new_list, 4)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if os.path.isfile(options['database']) == False:
|
|
|
|
if os.path.isfile(options['database']) == False:
|
|
|
|
print "Database file not found. Use the -d switch to specify a custom database path."
|
|
|
|
print "Database file not found. Use the -d switch to specify a custom database path."
|
|
|
|
exit(1)
|
|
|
|
exit(1)
|
|
|
@ -134,9 +160,11 @@ for message_id, sender, recipient, subject, timestamp, textbody, htmlbody, sha1_
|
|
|
|
|
|
|
|
|
|
|
|
# Sort by timestamp, ascending
|
|
|
|
# Sort by timestamp, ascending
|
|
|
|
sorted_list = sorted(email_list, key=lambda email: email[6].lower())
|
|
|
|
sorted_list = sorted(email_list, key=lambda email: email[6].lower())
|
|
|
|
|
|
|
|
render_index(sorted_list, "Sorted from old to new", "date_asc")
|
|
|
|
|
|
|
|
|
|
|
|
# Sort by timestamp, descending
|
|
|
|
# Sort by timestamp, descending
|
|
|
|
sorted_list.reverse()
|
|
|
|
sorted_list.reverse()
|
|
|
|
|
|
|
|
render_index(sorted_list, "Sorted from old to new", "date_desc")
|
|
|
|
|
|
|
|
|
|
|
|
# Sort by sender, ascending
|
|
|
|
# Sort by sender, ascending
|
|
|
|
sorted_list = sorted(email_list, key=lambda email: email[3].lower())
|
|
|
|
sorted_list = sorted(email_list, key=lambda email: email[3].lower())
|
|
|
|