Finalize porting built-in web app to Flask.

This commit is contained in:
Aldo Cortesi 2012-06-21 16:54:49 +12:00
parent f88e899274
commit cd8fba1d70
6 changed files with 71 additions and 83 deletions

View File

@ -1,6 +1,6 @@
import logging
from flask import Flask, jsonify, render_template
import version
import logging, pprint, cStringIO
from flask import Flask, jsonify, render_template, request
import version, rparse
logging.basicConfig(level="DEBUG")
app = Flask(__name__)
@ -29,75 +29,47 @@ def api_clear_log():
@app.route('/')
@app.route('/index.html')
def index():
return render_template("index.html", name="index", section="main")
return render_template("index.html", section="main")
@app.route('/help')
def help():
return render_template("help.html", section="help")
@app.route('/log')
def log():
return render_template("log.html", section="log", log=app.config["pathod"].get_log())
"""
class _Page(tornado.web.RequestHandler):
def render(self, name, **kwargs):
tornado.web.RequestHandler.render(self, name + ".html", **kwargs)
@app.route('/log/<int:lid>')
def onelog(lid):
l = pprint.pformat(app.config["pathod"].log_by_id(int(lid)))
return render_template("onelog.html", section="log", alog=l, lid=lid)
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")
"""
SANITY = 1024*1024
@app.route('/preview')
def preview():
spec = request.args["spec"]
args = dict(
spec = spec,
section = "main",
syntaxerror = None,
error = None
)
try:
r = rparse.parse(app.config["pathod"].request_settings, spec)
except rparse.ParseException, v:
args["syntaxerror"] = str(v)
args["marked"] = v.marked()
return render_template("preview.html", **args)
if r.length() > SANITY:
error = "Refusing to preview a response of %s bytes. This is for your own good."%r.length()
args["error"] = error
else:
s = cStringIO.StringIO()
r.serve(s)
args["output"] = s.getvalue()
return render_template("preview.html", **args)

View File

@ -35,6 +35,17 @@ class PathodHandler(tcp.BaseHandler):
ret = presp.serve(self.wfile)
if ret["disconnect"]:
self.close()
ret["request"] = dict(
path = path,
method = method,
headers = headers.lst,
#remote_address = self.request.connection.address,
#full_url = self.request.full_url(),
#query = self.request.query,
httpversion = httpversion,
#uri = self.request.uri,
)
self.server.add_log(ret)
else:
cc = wsgi.ClientConn(self.client_address)
@ -60,6 +71,10 @@ class Pathod(tcp.TCPServer):
self.log = []
self.logid = 0
@property
def request_settings(self):
return {}
def handle_connection(self, request, client_address):
PathodHandler(request, client_address, self)

View File

@ -1,4 +1,4 @@
{% extends frame.html %}
{% extends "frame.html" %}
{% block body %}
<!-- Text below generated with "markdown2 README.mkd" -->
@ -251,4 +251,4 @@ ascii
bytes
</code></pre>
{% end %}
{% endblock %}

View File

@ -1,4 +1,4 @@
{% extends frame.html %}
{% extends "frame.html" %}
{% block body %}
<form style="float: right" method="POST" action="/log/clear">
<button type="submit" class="btn">clear</button>
@ -10,17 +10,19 @@
<thead>
<tr>
<th>id</th>
<th>url</th>
<th>method</th>
<th>path</th>
</tr>
</thead>
<tbody>
{% for i in log %}
<tr>
<td>{{ i["id"] }}</td>
<td><a href="/log/{{ i["id"] }}">{{ i["request"]["full_url"] }}</a></td>
<td>{{ i["request"]["method"] }}</td>
<td><a href="/log/{{ i["id"] }}">{{ i["request"]["path"] }}</a></td>
</tr>
{% end %}
{% endfor %}
</tbody>
</table>
{% end %}
{% endblock %}

View File

@ -1,4 +1,4 @@
{% extends frame.html %}
{% extends "frame.html" %}
{% block body %}
<h2> Log entry {{ lid }} </h2>
<hr>
@ -6,5 +6,5 @@
{{ alog }}
</pre>
{% end %}
{% endblock %}

View File

@ -1,4 +1,4 @@
{% extends frame.html %}
{% extends "frame.html" %}
{% block body %}
<h1>Preview</h1>
@ -10,7 +10,6 @@
<h2> Error </h2>
<p style="color: #ff0000">{{ error }}</p>
{% else %}
<h2>Spec:</h2>
<pre>{{ spec }}</pre>
@ -19,6 +18,6 @@
<pre>{{ output }}</pre>
{% end %}
{% include previewform.html %}
{% end %}
{% endif %}
{% include "previewform.html" %}
{% endblock %}