2016-10-09 23:28:31 +01:00
|
|
|
from sanic import Sanic
|
|
|
|
from sanic.log import log
|
|
|
|
from sanic.response import json, text
|
|
|
|
from sanic.exceptions import ServerError
|
|
|
|
|
|
|
|
app = Sanic(__name__)
|
|
|
|
|
|
|
|
@app.route("/")
|
|
|
|
async def test_async(request):
|
|
|
|
return json({ "test": True })
|
|
|
|
|
|
|
|
@app.route("/sync", methods=['GET', 'POST'])
|
|
|
|
def test_sync(request):
|
|
|
|
return json({ "test": True })
|
|
|
|
|
|
|
|
@app.route("/dynamic/<name>/<id:int>")
|
|
|
|
def test_params(request, name, id):
|
|
|
|
return text("yeehaww {} {}".format(name, id))
|
|
|
|
|
|
|
|
@app.route("/exception")
|
|
|
|
def exception(request):
|
|
|
|
raise ServerError("It's dead jim")
|
|
|
|
|
|
|
|
# ----------------------------------------------- #
|
|
|
|
# Exceptions
|
|
|
|
# ----------------------------------------------- #
|
|
|
|
|
|
|
|
@app.exception(ServerError)
|
|
|
|
async def test(request, exception):
|
|
|
|
return json({ "exception": "{}".format(exception), "status": exception.status_code }, status=exception.status_code)
|
|
|
|
|
|
|
|
# ----------------------------------------------- #
|
|
|
|
# Read from request
|
|
|
|
# ----------------------------------------------- #
|
|
|
|
|
|
|
|
@app.route("/json")
|
|
|
|
def post_json(request):
|
|
|
|
return json({ "received": True, "message": request.json })
|
|
|
|
|
|
|
|
@app.route("/form")
|
|
|
|
def post_json(request):
|
2016-10-14 12:51:08 +01:00
|
|
|
return json({ "received": True, "form_data": request.form, "test": request.form.get('test') })
|
2016-10-09 23:28:31 +01:00
|
|
|
|
|
|
|
@app.route("/query_string")
|
|
|
|
def query_string(request):
|
|
|
|
return json({ "parsed": True, "args": request.args, "url": request.url, "query_string": request.query_string })
|
|
|
|
|
|
|
|
# ----------------------------------------------- #
|
|
|
|
# Run Server
|
|
|
|
# ----------------------------------------------- #
|
|
|
|
|
|
|
|
def before_start(loop):
|
|
|
|
log.info("OH OH OH OH OHHHHHHHH")
|
|
|
|
def before_stop(loop):
|
|
|
|
log.info("TRIED EVERYTHING")
|
|
|
|
|
|
|
|
app.run(host="0.0.0.0", port=8000, debug=True, before_start=before_start, before_stop=before_stop)
|
|
|
|
|
|
|
|
|