Easy timezones for Django (>=1.7) based on MaxMind GeoIP.
Project description
django-easy-timezones
Easy IP-based timezones for Django (>=1.7) based on MaxMind GeoIP, with IPv6 support.
Quick start
Install django-easy-timezones
pip install django-easy-timezones
Add “easy-timezones” to your INSTALLED_APPS setting like this:
INSTALLED_APPS = ( ... 'easy_timezones', )
Add EasyTimezoneMiddleware to your MIDDLEWARE_CLASSES
MIDDLEWARE_CLASSES = ( ... 'easy_timezones.middleware.EasyTimezoneMiddleware', )
(Optionally) Add a path to the MaxMind GeoIP cities databases (direct link because I’m nice) in your settings file:
GEOIP_DATABASE = '/path/to/your/geoip/database/GeoLiteCity.dat' GEOIPV6_DATABASE = '/path/to/your/geoip/database/GeoLiteCityv6.dat'
Enable localtime in your templates.
{% load tz %} The UTC time is {{ object.date }} {% localtime on %} The local time is {{ object.date }} {% endlocaltime %}
Twist one up, cause you’re done, homie!
Signals
You can also use signals to perform actions based on the timezone detection.
To hook into the Timezone detection event to, say, save it to the request’s user somewhere more permanent than a session, do something like this:
from easy_timezones.signals import detected_timezone @receiver(detected_timezone, sender=MyUserModel) def process_timezone(sender, instance, timezone, **kwargs): if instance.timezone != timezone: instance.timezone = timezone instance.save()
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Hashes for django-easy-timezones-0.6.2.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | b4983a2e306904ff83b681e4ad9ead623621cf041b52c88fbe94adbc6b54333c |
|
MD5 | 0d58c8d447f1510060f9319e4b9d9491 |
|
BLAKE2b-256 | 9d54bf7fbd2afbc06fa53322641e1c45435dc040baaf408e437ecf155505709a |