Merge branch 'onelab' of ssh://git.onelab.eu/git/myslice into onelab
[unfold.git] / myslice / urls.py
1 from django.conf.urls import patterns, include, url
2 from django.conf      import settings
3 from django.contrib import admin
4
5 # Uncomment the next two lines to enable the admin:
6 # from django.contrib import admin
7 # admin.autodiscover()
8
9 # to enable insert_above stuff
10 from django.template.loader import add_to_builtins
11 add_to_builtins('insert_above.templatetags.insert_tags')
12
13 from settings import auxiliaries, INSTALLED_APPS
14
15 import portal.platformsview
16 import portal.dashboardview
17 import portal.homeview
18 import portal.newsview
19
20 home_view=portal.homeview.HomeView.as_view()
21 dashboard_view=portal.dashboardview.DashboardView.as_view()
22 platforms_view=portal.platformsview.PlatformsView.as_view()
23
24 #import portal.testbedlist
25 import portal.sliceview
26 import portal.sliceresourceview
27
28 import portal.slicetabexperiment
29 import portal.slicetabinfo
30 import portal.slicetabtestbeds
31 import portal.slicetabusers
32 import portal.slicetabmeasurements 
33
34 #### high level choices
35 # main entry point (set to the / URL)
36 # beware that if this view is broken you end up in an endless cycle...
37 # maybe platforms_view would be best on the longer run
38 the_default_view=home_view
39 # where to be redirected after login
40 the_after_login_view=dashboard_view
41 # where to redirect when login is required
42 # might need another one ?
43 the_login_view=home_view
44 admin.autodiscover()
45 urls = [
46     '',
47     # Examples:
48     # url(r'^$', 'myslice.views.home', name='home'),
49     # url(r'^myslice/', include('myslice.foo.urls')),
50     # Uncomment the admin/doc line below to enable admin documentation:
51     # url(r'^admin/doc/', include('django.contrib.admindocs.urls')),
52     # Uncomment the next line to enable the admin:
53      url(r'^admin/', include(admin.site.urls)),
54     #
55     # default / view
56     (r'^/?$', the_default_view),
57     #
58     # login / logout
59     (r'^login-ok/?$', the_after_login_view, {'state': 'Welcome to MySlice'} ),
60     #
61     # seems to be what login_required uses to redirect ...
62     (r'^accounts/login/$', the_login_view),
63     (r'^login/?$', the_login_view),
64     (r'^logout/?$', 'auth.views.logout_user'),
65     #
66     # the manifold proxy
67     (r'^manifold/proxy/(?P<format>\w+)/?$', 'manifoldapi.manifoldproxy.proxy'),
68     #
69     #
70     # RESTful interface
71     (r'^rest/(?P<object_type>[^/]+)/(?P<object_name>[^/]+)?/?$', 'rest.get.dispatch'),
72     (r'^table/(?P<object_type>[^/]+)/(?P<object_name>[^/]+)?/?$', 'rest.get.dispatch'),
73     (r'^datatable/(?P<object_type>[^/]+)/(?P<object_name>[^/]+)?/?$', 'rest.get.dispatch'),
74     (r'^update/(?P<object_type>[^/]+)/(?P<object_name>[^/]+)?/?$', 'rest.update.dispatch'),
75     (r'^create/(?P<object_type>[^/]+)/(?P<object_name>[^/]+)?/?$', 'rest.create.dispatch'),
76     (r'^delete/(?P<object_type>[^/]+)/(?P<object_name>[^/]+)?/?$', 'rest.delete.dispatch'),
77     #
78     #
79     #(r'^view/?', include('view.urls')),
80     #(r'^list/slices', 'view.list.slices')
81     #
82     #
83     # Portal
84     (r'^news/?$', portal.newsview.NewsView.as_view()),
85     (r'^resources/(?P<slicename>[^/]+)/?$', portal.sliceresourceview.SliceResourceView.as_view()),
86     (r'^users/(?P<slicename>[^/]+)/?$', portal.slicetabusers.SliceUserView.as_view()),
87     
88     (r'^slice/(?P<slicename>[^/]+)/?$', portal.sliceview.SliceView.as_view()),
89     (r'^info/(?P<slicename>[^/]+)/?$', portal.slicetabinfo.SliceInfoView.as_view()),
90     (r'^testbeds/(?P<slicename>[^/]+)/?$', portal.slicetabtestbeds.SliceTabTestbeds.as_view()),
91     (r'^measurements/(?P<slicename>[^/]+)/?$', portal.slicetabmeasurements.SliceTabMeasurements.as_view()),
92     (r'^experiment/(?P<slicename>[^/]+)/?$', portal.slicetabexperiment.ExperimentView.as_view()),
93     url(r'^portal/', include('portal.urls')),
94
95     # SLA
96     url(r'^sla/', include('sla.urls')),
97 ]
98
99 #this one would not match the convention
100 # url(r'^debug/', include('debug_platform.urls')),
101 # but it was commented out anyways
102 for aux in auxiliaries:
103     if aux in INSTALLED_APPS:
104         urls.append ( url ( r'^%s/'%aux, include ('%s.urls'%aux )))
105
106 urlpatterns = patterns(*urls)