home > ctx

ctx

Other languages: français

Problem

You want to use contextual variables in your code such as the referring page or the client’s browser.

Solution

Using web.ctx makes this possible. First a little architecture: web.ctx is based on the class threadeddict a.k.a. ThreadedDict. This class creates a dictionary-like object that has attributes specific to the thread process id. This is nice because it lets us use a dictionary-like object when many users are accessing the system simultaneously, and the object will only have the data for the given HTTP request (no data is shared so the object is thread-safe).

web.ctx holds variables for each request that contain specific information to each request such as the client environment variable. Assuming you want to determine what the referring page was for a user accessing a page:

Example

class example:
    def GET(self):
        referer = web.ctx.env.get('HTTP_REFERER', 'http://google.com')
        raise web.seeother(referer)

This code uses web.ctx.env to access the HTTP_REFERER environment variable. If there isn’t one, it defaults to google.com. Finally, it redirects the user to the page they came from.

web.ctx is also useful because it can be set by a loadhook. Session data, for example, is set each time a request is handled and the data is stored in web.ctx. Since web.ctx is thread-safe, you can use the session data as if it were a regular python object.

Data Found in ctx

Request

  • environ a.k.a. env – a dictionary containing the standard WSGI environment variables
  • home – the base path for the application, including any parts “consumed” by outer applications http://example.org/admin
  • homedomain – ? (appears to be protocol + host) http://example.org
  • homepath – The part of the path requested by the user which was trimmed off the current app. That is homepath + path = the path actually requested in HTTP by the user. E.g. /admin This seems to be derived during startup from the environment variable REAL_SCRIPT_NAME. It affects what web.url() will prepend to supplied urls. This in turn affects where web.seeother() will go, which might interact badly with your url rewriting scheme (e.g. mod_rewrite)
  • host – the hostname (domain) and (if not default) the port requested by the user. E.g. example.org, example.org:8080
  • ip – the IP address of the user. E.g. xxx.xxx.xxx.xxx
  • method – the HTTP method used. E.g. GET
  • path – the path requested by the user, relative to the current application. If you are using subapplications, any part of the url matched by the outer application will be trimmed off. E.g. you have a main app in code.py, and a subapplication called admin.py. In code.py, you point /admin to admin.app. In admin.py, you point /stories to a class called stories. Within stories, web.ctx.path will be /stories, not /admin/stories. E.g. /articles/845
  • protocol – the protocol used. E.g. https
  • query – an empty string if there are no query arguments otherwise a ? followed by the query string. E.g. ?fourlegs=good&twolegs=bad
  • fullpath a.k.a. path + query – the path requested including query arguments but not including homepath. E.g. /articles/845?fourlegs=good&twolegs=bad

Response

  • status – the HTTP status code (default ‘200 OK’) 401 Unauthorized
  • headers – a list of 2-tuples containing HTTP headers
  • output – a string containing the response entity