Statistics
| Branch: | Tag: | Revision:

root / api / versions.py @ f4fe8796

History | View | Annotate | Download (4.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
from datetime import datetime
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 synnefo.api.util import api_method, isoformat
42

    
43

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

    
56
VERSIONS = [VERSION_1_1]
57

    
58
MEDIA_TYPES = [
59
    {'base': 'application/xml', 'type': 'application/vnd.openstack.compute-v1.1+xml'},
60
    {'base': 'application/json', 'type': 'application/vnd.openstack.compute-v1.1+json'}
61
]
62

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

    
76
@api_method('GET', atom_allowed=True)
77
def versions_list(request):
78
    # Normal Response Codes: 200, 203
79
    # Error Response Codes: 400, 413, 500, 503
80

    
81
    if request.serialization == 'xml':
82
        data = render_to_string('versions_list.xml', {'versions': VERSIONS})
83
    elif request.serialization == 'atom':
84
        now = isoformat(datetime.now())
85
        data = render_to_string('versions_list.atom', {'now': now,'versions': VERSIONS})
86
    else:
87
        data = json.dumps({'versions': {'values': VERSIONS}})
88

    
89
    return HttpResponse(data)
90

    
91
@api_method('GET', atom_allowed=True)
92
def version_details(request, api_version):
93
    # Normal Response Codes: 200, 203
94
    # Error Response Codes: computeFault (400, 500),
95
    #                       serviceUnavailable (503),
96
    #                       unauthorized (401),
97
    #                       badRequest (400),
98
    #                       overLimit(413)
99

    
100
    # We hardcode to v1.1 since it is the only one we support
101
    version = VERSION_1_1.copy()
102
    version['links'] = version['links'] + DESCRIBED_BY
103

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