module documentation

Undocumented

Class ​App​Context No summary
Class ​Request​Context No summary
Class _​App​Ctx​Globals A plain object. Used as a namespace for storing data during an application context.
Function after​_this​_request Executes a function after this request. This is useful to modify response objects. The function is passed the response object and has to return the same or a new one.
Function copy​_current​_request​_context No summary
Function has​_app​_context Works like has_request_context but for the application context. You can also just do a boolean check on the current_app object instead.
Function has​_request​_context No summary
Variable ​_sentinel Undocumented
def after_this_request(f):

Executes a function after this request. This is useful to modify response objects. The function is passed the response object and has to return the same or a new one.

Example:

@app.route('/')
def index():
    @after_this_request
    def add_header(response):
        response.headers['X-Foo'] = 'Parachute'
        return response
    return 'Hello World!'

This is more useful if a function other than the view function wants to modify a response. For instance think of a decorator that wants to add some headers without converting the return value into a response object.

New in version 0.9.
Parameters
f:AfterRequestCallableUndocumented
Returns
AfterRequestCallableUndocumented
def copy_current_request_context(f):

A helper function that decorates a function to retain the current request context. This is useful when working with greenlets. The moment the function is decorated a copy of the request context is created and then pushed when the function is called. The current session is also included in the copied request context.

Example:

import gevent
from flask import copy_current_request_context

@app.route('/')
def index():
    @copy_current_request_context
    def do_some_work():
        # do some work here, it can access flask.request or
        # flask.session like you would otherwise in the view function.
        ...
    gevent.spawn(do_some_work)
    return 'Regular response'
New in version 0.10.
Parameters
f:t.CallableUndocumented
Returns
t.CallableUndocumented
def has_app_context():

Works like has_request_context but for the application context. You can also just do a boolean check on the current_app object instead.

New in version 0.9.
Returns
boolUndocumented
def has_request_context():

If you have code that wants to test if a request context is there or not this function can be used. For instance, you may want to take advantage of request information if the request object is available, but fail silently if it is unavailable.

class User(db.Model):

    def __init__(self, username, remote_addr=None):
        self.username = username
        if remote_addr is None and has_request_context():
            remote_addr = request.remote_addr
        self.remote_addr = remote_addr

Alternatively you can also just test any of the context bound objects (such as request or g) for truthness:

class User(db.Model):

    def __init__(self, username, remote_addr=None):
        self.username = username
        if remote_addr is None and request:
            remote_addr = request.remote_addr
        self.remote_addr = remote_addr
New in version 0.7.
Returns
boolUndocumented
_sentinel =

Undocumented