aboutsummaryrefslogtreecommitdiffstats
path: root/blogthon.cgi
diff options
context:
space:
mode:
authorStefan Ritter <xeno@goliath.thehappy.de>2009-02-28 18:02:23 +0100
committerStefan Ritter <xeno@goliath.thehappy.de>2009-02-28 18:02:23 +0100
commitfc1b6997235fe0249b1f5fdf0e47d58734cee8f3 (patch)
treed10a158f360df9c9f5af2cefc50f2d0b8749589b /blogthon.cgi
Initial release
Diffstat (limited to 'blogthon.cgi')
-rwxr-xr-xblogthon.cgi137
1 files changed, 137 insertions, 0 deletions
diff --git a/blogthon.cgi b/blogthon.cgi
new file mode 100755
index 0000000..f85eb01
--- /dev/null
+++ b/blogthon.cgi
@@ -0,0 +1,137 @@
+#!/usr/bin/python
+
+# This program is free software. It comes without any warranty, to
+# the extent permitted by applicable law. You can redistribute it
+# and/or modify it under the terms of the Do What The Fuck You Want
+# To Public License, Version 2, as published by Sam Hocevar. See
+# http://sam.zoy.org/wtfpl/COPYING for more details.
+
+import cgi
+import os
+import time
+import glob
+import re
+import ConfigParser
+
+configuration = ConfigParser.ConfigParser()
+configuration.read('configuration')
+
+blog_title = configuration.get('personal', 'blog_title')
+keywords = configuration.get('personal', 'keywords')
+entries_dir = configuration.get('personal', 'entries_dir')
+entries_suffix = configuration.get('personal', 'entries_suffix')
+staticpages_dir = configuration.get('personal', 'staticpages_dir')
+style = configuration.get('look', 'style')
+entries_per_page = configuration.getint('look', 'entries_per_page')
+monthlist = configuration.get('look', 'monthlist')
+staticpages = configuration.get('look', 'staticpages')
+permalinks = configuration.get('look', 'permalinks')
+newest_first = configuration.get('look', 'newest_first')
+
+action = cgi.FieldStorage()
+month_display = action.getvalue('m')
+post_display = action.getvalue('p')
+static_display = action.getvalue('s')
+site_display = action.getvalue('i')
+if not month_display: month_display = ""
+if not post_display: post_display = ""
+if not static_display: static_display = ""
+if not site_display: site_display = ""
+
+print 'Content-type: text/html\n'
+print '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"'
+print ' "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">'
+print '<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">'
+print ' <head>'
+print ' <title>' + blog_title + '</title>'
+print ' <meta http-equiv="content-type" content="text/html; charset=utf-8" />'
+print ' <meta name="keywords" content="' + keywords + '" />'
+print ' <meta name="description" content="' + blog_title + '" />'
+print ' <link rel="stylesheet" type="text/css" href="styles/' + style + '" />'
+print ' </head>'
+print ' <body>'
+print ' <div class="title"><a href="?" class="title">' + blog_title + '</a></div>'
+
+entries = []
+entries_list = glob.glob(entries_dir + '*.' + entries_suffix)
+
+for entry in entries_list:
+ timestamp = os.stat(entry)
+ timestamp = time.localtime(timestamp[8])
+ entry = timestamp, entry
+ entries.append(entry)
+
+if newest_first:
+ entries.sort(reverse=True)
+else:
+ entries.sort()
+
+print ' <div class="sidebar">'
+
+if staticpages:
+ staticpages = []
+ staticpages_list = glob.glob(staticpages_dir + '*')
+ staticpages_list.sort()
+ print ' <div class="staticpages">'
+ for staticpage in staticpages_list:
+ title = re.sub('\w+?\/\d+?-', '', staticpage)
+ link = re.sub('\w+?\/', '', staticpage)
+ print ' &nbsp;<a href="?s=' + link + '">' + title + '</a>&nbsp;<br />'
+ if monthlist and staticpages_list != []: print ' <br />'
+ print ' </div>'
+
+if monthlist:
+ olddate = ""
+ print ' <div class="monthlist">'
+ for entry in entries:
+ date = time.strftime("%m%Y", entry[0])
+ date_display = time.strftime("%h %Y", entry[0])
+ if not olddate == date:
+ print ' <a href="?m=' + date + '">' + date_display + '</a><br />'
+ olddate = date
+ print ' </div>'
+
+print ' </div>'
+print ' <div class="content">'
+
+if static_display != "": # Show Staticpage
+ content = open(staticpages_dir + static_display, "r")
+ print ' <div class="entrytitle">' + re.sub('\d+?-', '', static_display) + '</div>'
+ print ' <div class="entry"><p>'
+ for line in content:
+ print ' ' + line.strip() + '<br />'
+ print ' </p></div>'
+ content.close()
+else: # Show regular entry
+ entry_counter = 0
+ for entry in entries:
+ date = time.strftime("%c", entry[0])
+ date_to_compare = time.strftime("%m%Y", entry[0]) # Needed for permalinks
+ entry = entry[1]
+ title = entry.replace('entries/', '', 1)
+ title = title.replace('.txt', '')
+ entry_counter += 1
+
+ if month_display == date_to_compare or not month_display:
+ if post_display == title or not post_display:
+ if entry_counter <= entries_per_page:
+ content = open(entry, "r")
+ if permalinks:
+ print ' <div class="entrytitle"><a href="?p=' + title + '" class="entrytitle">' + title + ' <small>(' + date + ')</small></a></div>'
+ else:
+ print ' <div class="entrytitle">' + title + ' <small>(' + date + ')</small></div>'
+ print ' <div class="entry"><p>'
+ for line in content:
+ print ' ' + line.strip() + '<br />'
+ print ' </p></div>'
+ print ' <br /><br />'
+ content.close()
+
+ if entry_counter > entries_per_page: # Display pagelist
+ print ' <div class="entry"><a href=?>[previous page]</a> <a href=?>[next page]</a></div>'
+
+print ' </div>'
+print ' </body>'
+print '</html>'
+
+# vim: set tw=0 ts=4: