Skip to main content

Sanic integration with Jinja2 in async mode [experimental]

Project description


Jinja2 in async mode with Sanic [experimental]

Build Status Latest Version Python Versions Tests Coverage

It is based on sanic-jinja2. It provides two decorators @template and @stream_template. The main change is in using render_async and generate_async for the decorator functions.

@stream_template is just and experimental way to make HTTP response via It gives you ability to decrease time to the first byte on response and stream long response during the processing template with data.

Example code

import asyncio
from sanic import Sanic
from sanic_asyncjinja2 import SanicAsyncJinja2

app = Sanic(__name__)
jinja = SanicAsyncJinja2()

@app.route('/', methods=["GET", ])
def index(request):
    return {"name": "world"}

@app.route('/slow_query', methods=["GET", ])
async def slow_handler(request):
    async def func1():
        await asyncio.sleep(2)
        return "name"

    async def func2():
        await asyncio.sleep(2)
        return "world"

    async def gfunc(k, v):
        key, value = await asyncio.gather(k, v)
        return {key: value}

    f1 = func1()
    f2 = func2()
    g = await gfunc(f1, f2)
    return g

# this is just a stupid idea
# to win the time to the first byte on response
# on one of our production servers
# it is helpful with big responses
@app.route('/simplestream', methods=["GET", ])
async def handler2(request):
    very_long_text = "Very long response here..." 
    return {"name": "world", "text": very_long_text}

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sanic-asyncjinja2-0.1.2.tar.gz (3.6 kB view hashes)

Uploaded source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page