django-urlcrypt is a Django app that encrypts information in urls, such as login credentials.
For example, assume I have url patterns that looks like this:
urlpatterns = patterns('',
url(r'^inbox/$', 'message_inbox', name='message_inbox'),
(r'^r/', include('urlcrypt.urls')),
)
Developer comments
I can use django-urlcrypt to generate a url for a user that looks like:
http://www.mydomain.com/r/TkNJBkNFAghDWkdFGPUAQEfcDUJfEBIREgEUFl1BQ18IQkdDUUcPSh4ADAYAWhYKHh8KHBsHEw
and will automatically log that person in and redirects them to /inbox/.
Installation
1. easy_install django-urlcrypt or pip install django-urlcrypt
2. Add urlcrypt to your INSTALLED_APPS
3. In urls.py add:
(r'^r/', include('urlcrypt.urls')),
Usage
In a view:
from django.core.urlresolvers import reverse
from urlcrypt import lib as urlcrypt
token = urlcrypt.generate_login_token(user, reverse('message_inbox'))
encoded_url = reverse('urlcrypt_redirect', args=(token,))
# yours will look slightly different because you have a different SECRET_KEY, but approximately
# encoded_url == /r/TkNJBkNFAghDWkdFGPUAQEfcDUJfEBIREgEUFl1BQ18IQkdDUUcPSh4ADAYAWhYKHh8KHBsHEw
In a template:
{% load urlcrypt_tags %}
< a href="{% encoded_url user message_inbox %}" >click me to log in as {{user.username}} and go to {% url message_inbox %}< /a >
Advanced lib usage:
from urlcrypt import lib as urlcrypt
message = {
'url': u'/users/following/',
'user_id': '12345'
}
token = urlcrypt.encode_token(message['user_id'], message['url'])
decoded_message = urlcrypt.decode_token(token, ('user_id', 'url', 'timestamp'))
>>> print token
TkNJBkNFAghDWkdFGPUAQEfcDUJfEBIREgEUFl1BQ18IQkdDUUcPSh4ADAYAWhYKHh8KHBsHEw
>>> print decoded_message
{'url': '/users/following', 'user_id': '12345'}
Settings
URLCRYPT_LOGIN_URL default: LOGIN_URL
If urlcrypt authentication fails, redirects to URLCRYPT_LOGIN_URL.
RUNNING_TESTS default: False
Set RUNNING_TESTS to True when running the urlcrypt tests.
Requirements:
- Python
Comments not found