Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / api / delegate.py @ 07419e58

History | View | Annotate | Download (3.2 kB)

1
# Copyright 2011, 2012, 2013 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
from django.http import HttpResponse
38
from django.views.decorators.csrf import csrf_exempt
39

    
40
from django.conf import settings
41

    
42
USER_CATALOG_URL = getattr(settings, 'CYCLADES_USER_CATALOG_URL', None)
43
USER_FEEDBACK_URL = getattr(settings, 'CYCLADES_USER_FEEDBACK_URL', None)
44

    
45
from objpool.http import PooledHTTPConnection
46

    
47
logger = logging.getLogger(__name__)
48

    
49

    
50
def proxy(request, url, headers={}, body=None):
51
    p = urlparse(url)
52

    
53
    kwargs = {}
54
    kwargs['headers'] = headers
55
    kwargs['headers'].update(request.META)
56
    kwargs['body'] = body
57
    kwargs['headers'].setdefault('content-type', 'application/json')
58
    kwargs['headers'].setdefault('content-length', len(body) if body else 0)
59

    
60
    with PooledHTTPConnection(p.netloc, p.scheme) as conn:
61
        conn.request(request.method, p.path + '?' + p.query, **kwargs)
62
        response = conn.getresponse()
63
        length = response.getheader('content-length', None)
64
        data = response.read(length)
65
        status = int(response.status)
66
        return HttpResponse(data, status=status)
67

    
68

    
69
@csrf_exempt
70
def delegate_to_feedback_service(request):
71
    logger.debug("Delegate feedback request to %s" % USER_FEEDBACK_URL)
72
    token = request.META.get('HTTP_X_AUTH_TOKEN')
73
    headers = {'X-Auth-Token': token}
74
    return proxy(request, USER_FEEDBACK_URL, headers=headers,
75
                 body=request.raw_post_data)
76

    
77

    
78
@csrf_exempt
79
def delegate_to_user_catalogs_service(request):
80
    token = request.META.get('HTTP_X_AUTH_TOKEN')
81
    headers = {'X-Auth-Token': token, 'content-type': 'application/json'}
82
    return proxy(request, USER_CATALOG_URL, headers=headers,
83
                 body=request.raw_post_data)