This commit is contained in:
bkfox
2019-08-07 01:45:27 +02:00
parent 324cf2ef0f
commit 248b77fca4
52 changed files with 794 additions and 384 deletions

View File

@ -1,6 +1,5 @@
import pytz
from django import shortcuts
from django.db.models import Q, Case, Value, When
from django.db.models import Q
from django.utils import timezone as tz
from .models import Station
@ -16,18 +15,18 @@ class AircoxMiddleware(object):
This middleware must be set after the middleware
'django.contrib.auth.middleware.AuthenticationMiddleware',
"""
def __init__(self, get_response):
self.get_response = get_response
def get_station(self, request):
""" Return station for the provided request """
expr = Q(default=True) | Q(hosts__contains=request.get_host())
#case = Case(When(hosts__contains=request.get_host(), then=Value(0)),
# case = Case(When(hosts__contains=request.get_host(), then=Value(0)),
# When(default=True, then=Value(32)))
return Station.objects.filter(expr).order_by('default').first()
# .annotate(resolve_priority=case) \
#.order_by('resolve_priority').first()
# .order_by('resolve_priority').first()
def init_timezone(self, request):
# note: later we can use http://freegeoip.net/ on user side if
@ -44,13 +43,10 @@ class AircoxMiddleware(object):
timezone = tz.get_current_timezone()
tz.activate(timezone)
def __call__(self, request):
self.init_timezone(request)
request.station = self.get_station(request)
try:
return self.get_response(request)
except Redirect as redirect:
return
except Redirect:
return