Mercurial > templog
view web/templog.py @ 50:cfcd2891b634
merge
author | Matt Johnston <matt@ucc.asn.au> |
---|---|
date | Sun, 24 Jun 2012 10:37:56 +0800 |
parents | 9b5b202129c3 |
children | 79761ee67134 |
line wrap: on
line source
#!/usr/bin/env python2.7 import binascii import hmac import zlib import datetime import time import bottle from bottle import route, request, response import config import log @route('/update', method='post') def update(): enc_lines = request.forms.lines mac = request.forms.hmac if hmac.new(config.HMAC_KEY, enc_lines).hexdigest() != mac: raise HTTPError(code = 403, output = "Bad key") lines = zlib.decompress(binascii.a2b_base64(enc_lines)).split('\n') log.parse(lines) return "OK" @route('/graph.png') def graph(): # url takes time in hours or days if 'day' in request.query: start_day = datetime.datetime.strptime(request.query.day, '%Y%m%d') start = time.mktime(start_day.timetuple()) length = int(request.query.length) * 3600 * 24 else: start_hour = datetime.datetime.strptime(request.query.hour, '%Y%m%d%H') start = time.mktime(start_hour.timetuple()) length = int(request.query.length) * 3600 response.set_header('Content-Type', 'image/png') return log.graph_png(start, length) @route('/') def top(): return bottle.template('top', urlparams=request.query_string) @route('/test') def test(): import config import os f = open('%s/testout' % config.DATA_PATH, 'a+') f.write("more") f.flush() f.close() return 'done' def main(): bottle.debug(True) bottle.run(server='cgi') #bottle.run(port=9999, reloader=True) if __name__ == '__main__': main()