Statistics
| Branch: | Tag: | Revision:

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

History | View | Annotate | Download (3.8 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
from logging import getLogger
35

    
36
from django.conf import settings
37
from django.http import HttpResponse
38
from django.template.loader import render_to_string
39
from django.utils import simplejson as json
40

    
41
from snf_django.lib import api
42

    
43

    
44
log = getLogger('synnefo.api')
45

    
46

    
47
VERSION_1_1 = {
48
    'id': 'v1.1',
49
    'status': 'CURRENT',
50
    'updated': '2011-04-01',
51
    'links': [
52
        {
53
            'rel': 'self',
54
            'href': settings.API_ROOT_URL,
55
        }
56
    ]
57
}
58

    
59
VERSIONS = [VERSION_1_1]
60

    
61
MEDIA_TYPES = [
62
    {'base': 'application/xml',
63
     'type': 'application/vnd.openstack.compute-v1.1+xml'},
64
    {'base': 'application/json',
65
     'type': 'application/vnd.openstack.compute-v1.1+json'}
66
]
67

    
68
DESCRIBED_BY = [
69
    {'rel': 'describedby',
70
     'type': 'application/pdf',
71
     'href': "http://docs.rackspacecloud.com/servers/api/"
72
             "v1.1/cs-devguide-20110125.pdf"},
73
    {'rel': 'describedby',
74
     'type': 'application/vnd.sun.wadl+xml',
75
     'href': "http://docs.rackspacecloud.com/servers/api/v1.1/"
76
             "application.wadl"}
77
]
78

    
79

    
80
@api.api_method(http_method='GET', user_required=True, logger=log)
81
def versions_list(request):
82
    # Normal Response Codes: 200, 203
83
    # Error Response Codes: 400, 413, 500, 503
84

    
85
    if request.serialization == 'xml':
86
        data = render_to_string('versions_list.xml', {'versions': VERSIONS})
87
    else:
88
        data = json.dumps({'versions': {'values': VERSIONS}})
89

    
90
    return HttpResponse(data)
91

    
92

    
93
@api.api_method('GET', user_required=True, logger=log)
94
def version_details(request, api_version):
95
    # Normal Response Codes: 200, 203
96
    # Error Response Codes: computeFault (400, 500),
97
    #                       serviceUnavailable (503),
98
    #                       unauthorized (401),
99
    #                       badRequest (400),
100
    #                       overLimit(413)
101

    
102
    log.debug('version_details %s', api_version)
103
    # We hardcode to v1.1 since it is the only one we support
104
    version = VERSION_1_1.copy()
105
    version['links'] = version['links'] + DESCRIBED_BY
106

    
107
    if request.serialization == 'xml':
108
        version['media_types'] = MEDIA_TYPES
109
        data = render_to_string('version_details.xml', {'version': version})
110
    else:
111
        version['media-types'] = MEDIA_TYPES
112
        data = json.dumps({'version': version})
113
    return HttpResponse(data)