Statistics
| Branch: | Tag: | Revision:

root / snf-cyclades-app / synnefo / plankton / urls.py @ 07602322

History | View | Annotate | Download (3.4 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 django.conf.urls.defaults import patterns, include
35
from django.http import HttpResponseNotAllowed
36
from snf_django.lib.api import api_endpoint_not_found
37

    
38
from synnefo.plankton import views
39

    
40

    
41
def demux(request):
42
    if request.method == 'GET':
43
        return views.list_images(request)
44
    elif request.method == 'POST':
45
        return views.add_image(request)
46
    else:
47
        return HttpResponseNotAllowed(['GET', 'POST'])
48

    
49

    
50
def demux_image(request, image_id):
51
    if request.method == "GET":
52
        return views.get_image(request, image_id)
53
    elif request.method == "HEAD":
54
        return views.get_image_meta(request, image_id)
55
    elif request.method == "PUT":
56
        return views.update_image(request, image_id)
57
    elif request.method == "DELETE":
58
        return views.delete_image(request, image_id)
59
    else:
60
        return HttpResponseNotAllowed(["GET", "HEAD", "PUT", "DELETE"])
61

    
62

    
63
def demux_image_members(request, image_id):
64
    if request.method == 'GET':
65
        return views.list_image_members(request, image_id)
66
    elif request.method == 'PUT':
67
        return views.update_image_members(request, image_id)
68
    else:
69
        return HttpResponseNotAllowed(['GET', 'PUT'])
70

    
71

    
72
def demux_members(request, image_id, member):
73
    if request.method == 'DELETE':
74
        return views.remove_image_member(request, image_id, member)
75
    elif request.method == 'PUT':
76
        return views.add_image_member(request, image_id, member)
77
    else:
78
        return HttpResponseNotAllowed(['DELETE', 'PUT'])
79

    
80

    
81
image_v1_patterns = patterns(
82
    '',
83
    (r'^images/$', demux),
84
    (r'^images/detail$', views.list_images, {'detail': True}),
85
    (r'^images/([\w-]+)$', demux_image),
86
    (r'^images/([\w-]+)/members$', demux_image_members),
87
    (r'^images/([\w-]+)/members/([\w@._-]+)$', demux_members),
88
    (r'^shared-images/([\w@._-]+)$', views.list_shared_images),
89
)
90

    
91
urlpatterns = patterns(
92
    '',
93
    (r'^v1.0/', include(image_v1_patterns)),
94
    (r'^.*', api_endpoint_not_found),
95
)