2012-06-19 04:57:57 +00:00
|
|
|
from flask import Flask, jsonify
|
|
|
|
import version
|
|
|
|
app = Flask(__name__)
|
2012-06-19 01:23:07 +00:00
|
|
|
|
2012-06-19 04:57:57 +00:00
|
|
|
@app.route('/api/info')
|
|
|
|
def api_info():
|
|
|
|
return jsonify(
|
|
|
|
version = version.IVERSION
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
"""
|
2012-06-19 01:23:07 +00:00
|
|
|
class APILog(tornado.web.RequestHandler):
|
|
|
|
def get(self):
|
|
|
|
self.write(
|
|
|
|
dict(
|
|
|
|
d = self.application.get_log()
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
class APILogClear(tornado.web.RequestHandler):
|
|
|
|
def post(self):
|
|
|
|
self.application.clear_log()
|
|
|
|
self.write("OK")
|
|
|
|
|
|
|
|
|
|
|
|
class APIShutdown(tornado.web.RequestHandler):
|
|
|
|
def post(self):
|
|
|
|
tornado.ioloop.IOLoop.instance().stop()
|
|
|
|
self.write("OK")
|
|
|
|
|
|
|
|
|
|
|
|
class APIInfo(tornado.web.RequestHandler):
|
|
|
|
def get(self):
|
|
|
|
self.write(
|
|
|
|
dict(
|
|
|
|
version = version.IVERSION
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
class _Page(tornado.web.RequestHandler):
|
|
|
|
def render(self, name, **kwargs):
|
|
|
|
tornado.web.RequestHandler.render(self, name + ".html", **kwargs)
|
|
|
|
|
|
|
|
|
|
|
|
class Index(_Page):
|
|
|
|
name = "index"
|
|
|
|
section = "main"
|
|
|
|
def get(self):
|
|
|
|
self.render(self.name, section=self.section, spec="")
|
|
|
|
|
|
|
|
|
|
|
|
class Preview(_Page):
|
|
|
|
name = "preview"
|
|
|
|
section = "main"
|
|
|
|
SANITY = 1024*1024
|
|
|
|
def get(self):
|
|
|
|
spec = self.get_argument("spec", None)
|
|
|
|
args = dict(
|
|
|
|
spec = spec,
|
|
|
|
section = self.section,
|
|
|
|
syntaxerror = None,
|
|
|
|
error = None
|
|
|
|
)
|
|
|
|
try:
|
|
|
|
r = rparse.parse(self.application.settings, spec)
|
|
|
|
except rparse.ParseException, v:
|
|
|
|
args["syntaxerror"] = str(v)
|
|
|
|
args["marked"] = v.marked()
|
|
|
|
return self.render(self.name, **args)
|
|
|
|
if r.length() > self.SANITY:
|
|
|
|
error = "Refusing to preview a response of %s bytes. This is for your own good."%r.length()
|
|
|
|
args["error"] = error
|
|
|
|
else:
|
|
|
|
d = utils.DummyRequest()
|
|
|
|
r.serve(d)
|
|
|
|
args["output"] = d.getvalue()
|
|
|
|
self.render(self.name, **args)
|
|
|
|
|
|
|
|
|
|
|
|
class Help(_Page):
|
|
|
|
name = "help"
|
|
|
|
section = "help"
|
|
|
|
def get(self):
|
|
|
|
self.render(self.name, section=self.section)
|
|
|
|
|
|
|
|
|
|
|
|
class Log(_Page):
|
|
|
|
name = "log"
|
|
|
|
section = "log"
|
|
|
|
def get(self):
|
|
|
|
self.render(self.name, section=self.section, log=self.application.log)
|
|
|
|
|
|
|
|
|
|
|
|
class OneLog(_Page):
|
|
|
|
name = "onelog"
|
|
|
|
section = "log"
|
|
|
|
def get(self, lid):
|
|
|
|
l = pprint.pformat(self.application.log_by_id(int(lid)))
|
|
|
|
self.render(self.name, section=self.section, alog=l, lid=lid)
|
|
|
|
|
|
|
|
|
|
|
|
class ClearLog(_Page):
|
|
|
|
def post(self):
|
|
|
|
self.application.clear_logs()
|
|
|
|
self.redirect("/log")
|
2012-06-19 04:57:57 +00:00
|
|
|
"""
|