Revision 68ed1683

b/snf-astakos-app/astakos/im/middleware.py
1
# Copyright 2011 GRNET S.A. All rights reserved.
2
#
3
# Redistribution and use in source and binary forms, with or
4
# without modification, are permitted provided that the following
5
# conditions are met:
6
#
7
#   1. Redistributions of source code must retain the above
8
#      copyright notice, this list of conditions and the following
9
#      disclaimer.
10
#
11
#   2. Redistributions in binary form must reproduce the above
12
#      copyright notice, this list of conditions and the following
13
#      disclaimer in the documentation and/or other materials
14
#      provided with the distribution.
15
#
16
# THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
17
# OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
20
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
23
# USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
24
# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
26
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27
# POSSIBILITY OF SUCH DAMAGE.
28
#
29
# The views and conclusions contained in the software and
30
# documentation are those of the authors and should not be
31
# interpreted as representing official policies, either expressed
32
# or implied, of GRNET S.A.
33

  
34
from urllib import unquote
35
from django.contrib.auth import authenticate, login
36

  
37
from astakos.im.settings import COOKIE_NAME
38
from astakos.im.models import AstakosUser
39

  
40
class CookieAuthenticationMiddleware(object):
41
    def process_request(self, request):
42
        assert hasattr(request, 'session'), "The Django authentication middleware requires session middleware to be installed. Edit your MIDDLEWARE_CLASSES setting to insert 'django.contrib.sessions.middleware.SessionMiddleware'."
43
        if request.user.is_authenticated():
44
            return None
45
        
46
        cookie = unquote(request.COOKIES.get(COOKIE_NAME, ''))
47
        email, sep, auth_token = cookie.partition('|')
48
        if not sep:
49
            return None
50
        
51
        try:
52
            user = authenticate(email=email, auth_token=auth_token)
53
            if user:
54
                request.user = user
55
            login(request, user)
56
        except:
57
            pass
58
        return None
b/snf-astakos-app/astakos/im/synnefo_settings.py
60 60

  
61 61
middlware_classes = [
62 62
    'django.contrib.auth.middleware.AuthenticationMiddleware',
63
    'astakos.im.middleware.CookieAuthenticationMiddleware',
63 64
    'synnefo.lib.middleware.LoggingConfigMiddleware',
64 65
    'synnefo.lib.middleware.SecureMiddleware'
65 66
]

Also available in: Unified diff