Statistics
| Branch: | Tag: | Revision:

root / snf-pithos-app / pithos / api / delegate.py @ 479c3051

History | View | Annotate | Download (3.6 kB)

1
# Copyright 2011-2012 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 logging
35

    
36
from urlparse import urlparse
37

    
38
from django.http import (
39
    HttpResponseNotFound, HttpResponseRedirect, HttpResponse)
40
from django.utils.http import urlencode
41
from django.views.decorators.csrf import csrf_exempt
42

    
43
from pithos.api.settings import (USER_LOGIN_URL, USER_FEEDBACK_URL,
44
                                 USER_CATALOG_URL)
45

    
46
from objpool.http import PooledHTTPConnection
47

    
48
logger = logging.getLogger(__name__)
49

    
50

    
51
def delegate_to_login_service(request):
52
    url = USER_LOGIN_URL
53
    if not url:
54
        return HttpResponseNotFound()
55

    
56
    p = urlparse(url)
57
    if request.is_secure():
58
        proto = 'https://'
59
    else:
60
        proto = 'http://'
61
    params = dict([(k, v) for k, v in request.GET.items()])
62
    uri = proto + p.netloc + p.path + '?' + urlencode(params)
63
    return HttpResponseRedirect(uri)
64

    
65

    
66
def proxy(request, url, headers=None, body=None):
67
    p = urlparse(url)
68

    
69
    kwargs = {}
70
    if headers is None:
71
        headers = {}
72
    kwargs["headers"] = headers
73
    kwargs['headers'].update(request.META)
74
    kwargs['body'] = body
75
    kwargs['headers'].setdefault('content-type', 'application/json')
76
    kwargs['headers'].setdefault('content-length', len(body) if body else 0)
77

    
78
    with PooledHTTPConnection(p.netloc, p.scheme) as conn:
79
        conn.request(request.method, p.path + '?' + p.query, **kwargs)
80
        response = conn.getresponse()
81
        length = response.getheader('content-length', None)
82
        data = response.read(length)
83
        status = int(response.status)
84
        return HttpResponse(data, status=status)
85

    
86

    
87
@csrf_exempt
88
def delegate_to_feedback_service(request):
89
    token = request.META.get('HTTP_X_AUTH_TOKEN')
90
    headers = {'X-Auth-Token': token}
91
    return proxy(
92
        request, USER_FEEDBACK_URL, headers=headers, body=request.raw_post_data)
93

    
94

    
95
@csrf_exempt
96
def delegate_to_user_catalogs_service(request):
97
    token = request.META.get('HTTP_X_AUTH_TOKEN')
98
    headers = {'X-Auth-Token': token, 'content-type': 'application/json'}
99
    return proxy(
100
        request, USER_CATALOG_URL, headers=headers, body=request.raw_post_data)