src/cm/middleware.py
author gibus
Mon, 08 Nov 2010 15:28:45 +0100
changeset 333 f080de4cad76
parent 285 1070d52adc11
child 475 782d40ecf7c3
permissions -rw-r--r--
Fix browsing by modifications, take into account every comment in a thread (instead of only the first two levels in each thread).

from cm.exception import UnauthorizedException 
from django.conf import settings
from django.http import HttpResponseServerError,HttpResponseRedirect
from django.core.urlresolvers import reverse
from urllib import urlencode

class CmMiddleware(object):
    
    def process_exception(self, request, exception):
        if settings.DEBUG:
            import sys, traceback
            traceback.print_exc()
        if type(exception) == UnauthorizedException:
            if request.user.is_anonymous():
                query = urlencode({'next': request.META['PATH_INFO'], 'q' : request.META['QUERY_STRING'] })
                login_url = reverse('login') + '?'  + query
                return HttpResponseRedirect(login_url)
            else:
                redirect_url = reverse('unauthorized')
                return HttpResponseRedirect(redirect_url)
        raise