Skip to content

Contains middleware for storing each django request in threadlocal storage and contains utilities for helping retrieve that request.

License

Notifications You must be signed in to change notification settings

ar45/django-threadlocals

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Setup/Usage

Install using pip install django-threadlocals

Add "threadlocals.middleware.ThreadLocalMiddleware" to your MIDDLEWARE_CLASSES setting. Then use it as follows:

Example usage:

`from threadlocals.threadlocals import get_current_request

request = get_current_request()`

Caveat Emptor

Storing the request in threadlocals goes against several django core developers' strong inclinations against using threadlocals. See this thread on django-users for a more in-depth discussion. We recommend you not do this unless you have a really good reason to do so. We feel like we had a really good reason (the only one we've come across so far): Having the request in threadlocals is the core piece that allowed us to build a true multi-tenant system on top of django where the site is resolved dynamically based on the current host, and objects are filtered based on the current host. With the current version of django, this is nearly impossible to do without the request in threadlocals. This was a very significant and advanced undertaking, but we're happy with the results.

Tests

To run tests:

python tester/manage.py test

About

Contains middleware for storing each django request in threadlocal storage and contains utilities for helping retrieve that request.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%