Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / plankton / util.py @ 2035039b

History | View | Annotate | Download (3.1 kB)

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
import datetime
35

    
36
from functools import wraps
37
from logging import getLogger
38
from traceback import format_exc
39

    
40
from django.conf import settings
41
from django.http import (HttpResponse, HttpResponseBadRequest,
42
                         HttpResponseServerError)
43

    
44
from synnefo.plankton.backend import ImageBackend, BackendException
45

    
46

    
47
log = getLogger('synnefo.plankton')
48

    
49

    
50
def get_user_from_token(token):
51
    return None
52

    
53

    
54
def get_request_user(request):
55
    user = get_user_from_token(request.META.get('HTTP_X_AUTH_TOKEN'))
56
    if not user:
57
        user = get_user_from_token(request.COOKIES.get('X-Auth-Token'))
58
    return user
59

    
60

    
61
def plankton_method(method):
62
    def decorator(func):
63
        @wraps(func)
64
        def wrapper(request, *args, **kwargs):
65
            try:
66
                if request.method != method:
67
                    return HttpResponse(status=405)
68
                if not request.user:
69
                    return HttpResponse(status=401)
70
                request.backend = ImageBackend(request.user)
71
                return func(request, *args, **kwargs)
72
            except (AssertionError, BackendException) as e:
73
                message = e.args[0] if e.args else ''
74
                return HttpResponseBadRequest(message)
75
            except Exception as e:
76
                if settings.DEBUG:
77
                    message = format_exc(e)
78
                else:
79
                    message = ''
80
                log.exception(e)
81
                return HttpResponseServerError(message)
82
            finally:
83
                if hasattr(request, 'backend'):
84
                    request.backend.close()
85
        return wrapper
86
    return decorator