summaryrefslogtreecommitdiffstats
path: root/django_authopenid/middleware.py
blob: 2be8da9077f3cf32bbfc3723a61917ab0f0fece8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
# -*- coding: utf-8 -*-
from django_authopenid import mimeparse
from django.http import HttpResponseRedirect
from django.core.urlresolvers import reverse
from django.conf import settings
import logging

__all__ = ["OpenIDMiddleware"]

class OpenIDMiddleware(object):
    """
    Populate request.openid. This comes either from cookie or from
    session, depending on the presence of OPENID_USE_SESSIONS.
    """
    def process_request(self, request):
        request.openid = request.session.get('openid', None)
        logging.debug('openid in session is: %s' % str(request.openid))
    
    def process_response(self, request, response):
        if response.status_code != 200 or len(response.content) < 200:
            return response
        path = request.get_full_path()
        if path == "/" and request.META.has_key('HTTP_ACCEPT') and \
                mimeparse.best_match(['text/html', 'application/xrds+xml'], 
                    request.META['HTTP_ACCEPT']) == 'application/xrds+xml':
            logging.debug('redirecting to yadis_xrdf:%s' % reverse('yadis_xrdf'))
            return HttpResponseRedirect(reverse('yadis_xrdf'))
        return response