urls.py 9.97 KB
Newer Older
1
from django.conf import settings
2
from django.conf.urls import patterns, include, url
cahrens committed
3
# There is a course creators admin table.
4
from ratelimitbackend import admin
5

6
from cms.djangoapps.contentstore.views.program import ProgramAuthoringView, ProgramsIdTokenView
7
from cms.djangoapps.contentstore.views.organization import OrganizationListView
8
from student.views import LogoutView
9

cahrens committed
10
admin.autodiscover()
11

12 13 14 15
# Pattern to match a course key or a library key
COURSELIKE_KEY_PATTERN = r'(?P<course_key_string>({}|{}))'.format(
    r'[^/]+/[^/]+/[^/]+', r'[^/:]+:[^/+]+\+[^/+]+(\+[^/]+)?'
)
16 17 18
# Pattern to match a library key only
LIBRARY_KEY_PATTERN = r'(?P<library_key_string>library-v1:[^/+]+\+[^/+]+)'

stv committed
19 20
urlpatterns = patterns(
    '',
21 22 23 24 25 26 27 28 29

    url(r'^transcripts/upload$', 'contentstore.views.upload_transcripts', name='upload_transcripts'),
    url(r'^transcripts/download$', 'contentstore.views.download_transcripts', name='download_transcripts'),
    url(r'^transcripts/check$', 'contentstore.views.check_transcripts', name='check_transcripts'),
    url(r'^transcripts/choose$', 'contentstore.views.choose_transcripts', name='choose_transcripts'),
    url(r'^transcripts/replace$', 'contentstore.views.replace_transcripts', name='replace_transcripts'),
    url(r'^transcripts/rename$', 'contentstore.views.rename_transcripts', name='rename_transcripts'),
    url(r'^transcripts/save$', 'contentstore.views.save_transcripts', name='save_transcripts'),

30
    url(r'^preview/xblock/(?P<usage_key_string>.*?)/handler/(?P<handler>[^/]*)(?:/(?P<suffix>.*))?$',
31
        'contentstore.views.preview_handler', name='preview_handler'),
32

33
    url(r'^xblock/(?P<usage_key_string>.*?)/handler/(?P<handler>[^/]*)(?:/(?P<suffix>.*))?$',
34 35
        'contentstore.views.component_handler', name='component_handler'),

36
    url(r'^xblock/resource/(?P<block_type>[^/]*)/(?P<uri>.*)$',
37
        'openedx.core.djangoapps.common_views.xblock.xblock_resource', name='xblock_resource_url'),
38

39
    url(r'^not_found$', 'contentstore.views.not_found', name='not_found'),
Lyla Fischer committed
40
    url(r'^server_error$', 'contentstore.views.server_error', name='server_error'),
41
    url(r'^organizations$', OrganizationListView.as_view(), name='organizations'),
42

43 44
    # noop to squelch ajax errors
    url(r'^event$', 'contentstore.views.event', name='event'),
Calen Pennington committed
45

46
    url(r'^xmodule/', include('pipeline_js.urls')),
47
    url(r'^heartbeat$', include('heartbeat.urls')),
48

Andy Armstrong committed
49
    url(r'^user_api/', include('openedx.core.djangoapps.user_api.legacy_urls')),
asadiqbal committed
50 51 52 53 54 55 56 57

    url(r'^i18n/', include('django.conf.urls.i18n')),

    # User API endpoints
    url(r'^api/user/', include('openedx.core.djangoapps.user_api.urls')),

    # Update session view
    url(r'^lang_pref/session_language', 'lang_pref.views.update_session_language', name='session_language'),
58 59 60

    # Darklang View to change the preview language (or dark language)
    url(r'^update_lang/', include('dark_lang.urls', namespace='darklang')),
61
)
62

63
# User creation and updating views
64 65
urlpatterns += patterns(
    '',
66

67
    url(r'^create_account$', 'student.views.create_account', name='create_account'),
68 69 70 71
    url(r'^activate/(?P<key>[^/]*)$', 'student.views.activate_account', name='activate'),

    # ajax view that actually does the work
    url(r'^login_post$', 'student.views.login_user', name='login_post'),
72
    url(r'^logout$', LogoutView.as_view(), name='logout'),
David Baumgold committed
73
)
74

75 76 77 78
# restful api
urlpatterns += patterns(
    'contentstore.views',

79 80 81 82
    url(r'^$', 'howitworks', name='homepage'),
    url(r'^howitworks$', 'howitworks'),
    url(r'^signup$', 'signup', name='signup'),
    url(r'^signin$', 'login_page', name='login'),
83
    url(r'^request_course_creator$', 'request_course_creator', name='request_course_creator'),
84

85
    url(r'^course_team/{}(?:/(?P<email>.+))?$'.format(COURSELIKE_KEY_PATTERN), 'course_team_handler'),
86
    url(r'^course_info/{}$'.format(settings.COURSE_KEY_PATTERN), 'course_info_handler'),
87
    url(
88
        r'^course_info_update/{}/(?P<provided_id>\d+)?$'.format(settings.COURSE_KEY_PATTERN),
89
        'course_info_update_handler'
90
    ),
91
    url(r'^home/?$', 'course_listing', name='home'),
92
    url(
93
        r'^course/{}/search_reindex?$'.format(settings.COURSE_KEY_PATTERN),
94 95 96
        'course_search_index_handler',
        name='course_search_index_handler'
    ),
97
    url(r'^course/{}?$'.format(settings.COURSE_KEY_PATTERN), 'course_handler', name='course_handler'),
Andy Armstrong committed
98 99
    url(r'^course_notifications/{}/(?P<action_state_id>\d+)?$'.format(settings.COURSE_KEY_PATTERN),
        'course_notifications_handler'),
Mathew Peterson committed
100
    url(r'^course_rerun/{}$'.format(settings.COURSE_KEY_PATTERN), 'course_rerun_handler', name='course_rerun_handler'),
101 102 103
    url(r'^container/{}$'.format(settings.USAGE_KEY_PATTERN), 'container_handler'),
    url(r'^orphan/{}$'.format(settings.COURSE_KEY_PATTERN), 'orphan_handler'),
    url(r'^assets/{}/{}?$'.format(settings.COURSE_KEY_PATTERN, settings.ASSET_KEY_PATTERN), 'assets_handler'),
104 105 106
    url(r'^import/{}$'.format(COURSELIKE_KEY_PATTERN), 'import_handler'),
    url(r'^import_status/{}/(?P<filename>.+)$'.format(COURSELIKE_KEY_PATTERN), 'import_status_handler'),
    url(r'^export/{}$'.format(COURSELIKE_KEY_PATTERN), 'export_handler'),
107
    url(r'^xblock/outline/{}$'.format(settings.USAGE_KEY_PATTERN), 'xblock_outline_handler'),
108
    url(r'^xblock/container/{}$'.format(settings.USAGE_KEY_PATTERN), 'xblock_container_handler'),
109 110 111 112 113 114 115 116
    url(r'^xblock/{}/(?P<view_name>[^/]+)$'.format(settings.USAGE_KEY_PATTERN), 'xblock_view_handler'),
    url(r'^xblock/{}?$'.format(settings.USAGE_KEY_PATTERN), 'xblock_handler'),
    url(r'^tabs/{}$'.format(settings.COURSE_KEY_PATTERN), 'tabs_handler'),
    url(r'^settings/details/{}$'.format(settings.COURSE_KEY_PATTERN), 'settings_handler'),
    url(r'^settings/grading/{}(/)?(?P<grader_index>\d+)?$'.format(settings.COURSE_KEY_PATTERN), 'grading_handler'),
    url(r'^settings/advanced/{}$'.format(settings.COURSE_KEY_PATTERN), 'advanced_settings_handler'),
    url(r'^textbooks/{}$'.format(settings.COURSE_KEY_PATTERN), 'textbooks_list_handler'),
    url(r'^textbooks/{}/(?P<textbook_id>\d[^/]*)$'.format(settings.COURSE_KEY_PATTERN), 'textbooks_detail_handler'),
117
    url(r'^videos/{}$'.format(settings.COURSE_KEY_PATTERN), 'videos_handler'),
118
    url(r'^video_encodings_download/{}$'.format(settings.COURSE_KEY_PATTERN), 'video_encodings_download'),
119
    url(r'^group_configurations/{}$'.format(settings.COURSE_KEY_PATTERN), 'group_configurations_list_handler'),
120 121
    url(r'^group_configurations/{}/(?P<group_configuration_id>\d+)(/)?(?P<group_id>\d+)?$'.format(
        settings.COURSE_KEY_PATTERN), 'group_configurations_detail_handler'),
122
    url(r'^api/val/v0/', include('edxval.urls')),
123 124
)

Andy Armstrong committed
125
JS_INFO_DICT = {
Steve Strassmann committed
126
    'domain': 'djangojs',
127 128
    # We need to explicitly include external Django apps that are not in LOCALE_PATHS.
    'packages': ('openassessment',),
David Baumgold committed
129
}
Steve Strassmann committed
130

131 132 133 134
if settings.FEATURES.get('ENABLE_CONTENT_LIBRARIES'):
    urlpatterns += (
        url(r'^library/{}?$'.format(LIBRARY_KEY_PATTERN),
            'contentstore.views.library_handler', name='library_handler'),
135 136
        url(r'^library/{}/team/$'.format(LIBRARY_KEY_PATTERN),
            'contentstore.views.manage_library_users', name='manage_library_users'),
137 138
    )

139
if settings.FEATURES.get('ENABLE_EXPORT_GIT'):
140 141 142 143 144 145 146
    urlpatterns += (url(
        r'^export_git/{}$'.format(
            settings.COURSE_KEY_PATTERN,
        ),
        'contentstore.views.export_git',
        name='export_git',
    ),)
147

Carson Gee committed
148
if settings.FEATURES.get('ENABLE_SERVICE_STATUS'):
149 150
    urlpatterns += patterns(
        '',
151 152 153
        url(r'^status/', include('service_status.urls')),
    )

154 155 156 157 158 159
if settings.FEATURES.get('AUTH_USE_CAS'):
    urlpatterns += (
        url(r'^cas-auth/login/$', 'external_auth.views.cas_login', name="cas-login"),
        url(r'^cas-auth/logout/$', 'django_cas.views.logout', {'next_page': '/'}, name="cas-logout"),
    )

160
urlpatterns += patterns('', url(r'^admin/', include(admin.site.urls)),)
cahrens committed
161

ihoover committed
162
# enable automatic login
163
if settings.FEATURES.get('AUTOMATIC_AUTH_FOR_TESTING'):
ihoover committed
164 165 166 167
    urlpatterns += (
        url(r'^auto_auth$', 'student.views.auto_auth'),
    )

168 169 170 171 172 173
# enable entrance exams
if settings.FEATURES.get('ENTRANCE_EXAMS'):
    urlpatterns += (
        url(r'^course/{}/entrance_exam/?$'.format(settings.COURSE_KEY_PATTERN), 'contentstore.views.entrance_exam'),
    )

174 175 176 177 178 179 180 181 182 183 184 185 186
# Enable Web/HTML Certificates
if settings.FEATURES.get('CERTIFICATES_HTML_VIEW'):
    urlpatterns += (
        url(r'^certificates/activation/{}/'.format(settings.COURSE_KEY_PATTERN),
            'contentstore.views.certificates.certificate_activation_handler'),
        url(r'^certificates/{}/(?P<certificate_id>\d+)/signatories/(?P<signatory_id>\d+)?$'.format(
            settings.COURSE_KEY_PATTERN), 'contentstore.views.certificates.signatory_detail_handler'),
        url(r'^certificates/{}/(?P<certificate_id>\d+)?$'.format(settings.COURSE_KEY_PATTERN),
            'contentstore.views.certificates.certificates_detail_handler'),
        url(r'^certificates/{}$'.format(settings.COURSE_KEY_PATTERN),
            'contentstore.views.certificates.certificates_list_handler')
    )

187 188 189 190 191 192
# Maintenance Dashboard
urlpatterns += patterns(
    '',
    url(r'^maintenance/', include('maintenance.urls', namespace='maintenance')),
)

193
urlpatterns += (
194 195 196
    # These views use a configuration model to determine whether or not to
    # display the Programs authoring app. If disabled, a 404 is returned.
    url(r'^programs/id_token/$', ProgramsIdTokenView.as_view(), name='programs_id_token'),
197 198 199 200
    # Drops into the Programs authoring app, which handles its own routing.
    url(r'^program/', ProgramAuthoringView.as_view(), name='programs'),
)

201 202 203 204 205 206 207
if settings.DEBUG:
    try:
        from .urls_dev import urlpatterns as dev_urlpatterns
        urlpatterns += dev_urlpatterns
    except ImportError:
        pass

208
if 'debug_toolbar' in settings.INSTALLED_APPS:
209 210 211 212 213
    import debug_toolbar
    urlpatterns += (
        url(r'^__debug__/', include(debug_toolbar.urls)),
    )

214
# Custom error pages
215
# pylint: disable=invalid-name
216 217
handler404 = 'contentstore.views.render_404'
handler500 = 'contentstore.views.render_500'
218 219 220

# display error page templates, for testing purposes
urlpatterns += (
221 222
    url(r'^404$', handler404),
    url(r'^500$', handler500),
223
)