#!/usr/bin/env python3 import json import operator import os import cleancss import tornado.httpclient import tornado.ioloop import tornado.web from config import web as config import db class BaseHandler(tornado.web.RequestHandler): def render(self, *args, **kwargs): kwargs['host'] = config.host return super(BaseHandler, self).render(*args, **kwargs) def render_string(self, *args, **kwargs): s = super(BaseHandler, self).render_string(*args, **kwargs) return s.replace(b'\n', b'') # this is like Django's {% spaceless %} class MainHandler(BaseHandler): def get(self): self.render('home.html') class SearchHandler(BaseHandler): def get(self): q = self.get_argument('q') with db.cursor() as c: corps = db.query(c, ''' SELECT DISTINCT corporation_id, corporation_name FROM characters WHERE corporation_name LIKE ? ''', '%{}%'.format(q)) self.render('search.html', corps=corps) class CSSHandler(tornado.web.RequestHandler): def get(self, css_path): css_path = os.path.join(os.path.dirname(__file__), 'web', 'static', css_path) + '.ccss' with open(css_path, 'r') as f: self.set_header('Content-Type', 'text/css') self.write(cleancss.convert(f)) if __name__ == '__main__': tornado.web.Application( handlers=[ (r'/', MainHandler), (r'/search', SearchHandler), (r"/(css/.+)\.css", CSSHandler), ], template_path=os.path.join(os.path.dirname(__file__), 'web/templates'), cookie_secret=config.cookie_secret, debug=config.debug, ).listen(config.port) print('listening on :%d' % config.port) tornado.ioloop.IOLoop.instance().start()