diff options
Diffstat (limited to 'project/urls.py')
-rw-r--r-- | project/urls.py | 194 |
1 files changed, 194 insertions, 0 deletions
diff --git a/project/urls.py b/project/urls.py new file mode 100644 index 0000000..9ffabfc --- /dev/null +++ b/project/urls.py @@ -0,0 +1,194 @@ +from django.conf import settings +from django.conf.urls.defaults import include +from django.conf.urls.defaults import patterns +from django.conf.urls.defaults import url +from django.contrib import admin +from django.views.generic.simple import direct_to_template +from django.views.generic.simple import redirect_to + + +admin.autodiscover() + +PROGRAM_PATTERN_CORE = r'[a-z](?:[0-9a-z]|_[0-9a-z])*' +EVENT_PATTERN_CORE =r'(?:[0-9a-z]|_[0-9a-z])*' +SCOPE_ARG_PATTERN = r'(?P<scope>%s/%s)' % ( + PROGRAM_PATTERN_CORE, EVENT_PATTERN_CORE) + +sitemaps = {} + +# Admin +urlpatterns = patterns('', + (r'^admin/', include(admin.site.urls)), + (r'^comments/', include('django.contrib.comments.urls')), + (r'^robots\.txt$', include('robots.urls')), + (r'^sitemap\.xml$', 'django.contrib.sitemaps.views.sitemap', {'sitemaps': sitemaps}), + url(r'^$', redirect_to, {'url': '/%s/' % (settings.CURRENT_SCOPE)}), + url(r'^%s/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "home.html"}, name='home'), +) + +# Talks, etc. +urlpatterns += patterns('project.scipycon.talk.views', + url(r'^%s/talks/$' % (SCOPE_ARG_PATTERN), + 'list_talks', name='list_talks'), + url(r'^%s/my-talks/$' % (SCOPE_ARG_PATTERN), + 'list_my_talks', name='list_my_talks'), + url(r'^%s/talks/talk/(?P<id>\d+)/$' % (SCOPE_ARG_PATTERN), + 'talk', name='talk_detail'), + url(r'^%s/submit-talk/$' % (SCOPE_ARG_PATTERN), + 'submit_talk', name='scipycon_submit_talk'), + url(r'^%s/edit-talk/(?P<id>\d+)/$' % (SCOPE_ARG_PATTERN), + 'edit_talk', name='scipycon_edit_talk'), + url(r'^%s/list-talks/(?P<id>\d+)/$' % (SCOPE_ARG_PATTERN), + 'list_talks', name='scipycon_list_talk'), + url(r'^%s/download_slides/$' % (SCOPE_ARG_PATTERN), + 'download_slides', name='scipycon_download_slides'), + url(r'^%s/download_videos/$' % (SCOPE_ARG_PATTERN), + 'download_videos', name='scipycon_download_videos'), + + ) + +# Registration +urlpatterns += patterns('project.scipycon.registration.views', + url(r'^%s/registrations/$' % (SCOPE_ARG_PATTERN), 'registrations', + name='scipycon_registrations'), + url(r'^%s/submit-registration/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "registration/submit-registration.html"}, + name='scipycon_submit_registration'), + url(r'^%s/edit-registration/(?P<id>\d+)/$' % (SCOPE_ARG_PATTERN), + 'edit_registration', name='scipycon_edit_registration'), + url(r'^%s/regstats/$'% (SCOPE_ARG_PATTERN), + 'regstats', name="regstats"), + url(r'^%s/regstats/download$'% (SCOPE_ARG_PATTERN), + 'regstats_download', name="regstats_download"), + url(r'^%s/manage_payments/$'% (SCOPE_ARG_PATTERN), + 'manage_payments', name="scipycon_manage_payments"), + ) + +# Authentication and Profile +urlpatterns += patterns('project.scipycon.user.views', + url(r'^%s/login/$' % (SCOPE_ARG_PATTERN), + 'login', name='scipycon_login'), + url(r'^%s/logout/$' % (SCOPE_ARG_PATTERN), + 'logout', name='scipycon_logout'), + url(r'^%s/account/$' % (SCOPE_ARG_PATTERN), + 'account', name='scipycon_account'), + url(r'^%s/password/$' % (SCOPE_ARG_PATTERN), + 'password', name='scipycon_password'), # change pwd + url(r'^%s/username/$' % (SCOPE_ARG_PATTERN), + 'username', name='scipycon_username'), # change uname + url(r'^%s/edit-profile/$' % (SCOPE_ARG_PATTERN), + 'edit_profile', name='scipycon_edit_profile'), + url(r'^%s/get-usernames/$' % (SCOPE_ARG_PATTERN), + 'get_usernames', name='scipycon_get_usernames'), + url(r'^%s/get-user-dump/$' % (SCOPE_ARG_PATTERN), + 'get_user_dump', name='scipycon_get_usernames'), + url(r'^%s/badge/$' % (SCOPE_ARG_PATTERN), + 'badge', name='scipycon_badge')) + + +# Proceedings +urlpatterns += patterns('project.scipycon.proceedings.views', + url(r'^%s/proceedings/submit/$' % (SCOPE_ARG_PATTERN), 'submit', + name='scipycon_submit_proceedings'), + url(r'^%s/proceedings/submit/(?P<id>\d+)/$' % (SCOPE_ARG_PATTERN), + 'submit', name='scipycon_submit_proceedings'), + url(r'^%s/proceedings/show_paper/(?P<id>\d+)/$' % (SCOPE_ARG_PATTERN), + 'show_paper', name='scipycon_show_paper'), + ) + +# About pages and all other static html pages +urlpatterns += patterns('', + url(r'^%s/about/accommodation/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/accommodation.html"}, + name='scipycon_accommodation'), + url(r'^%s/about/food/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/food.html"}, + name='scipycon_food'), + url(r'^%s/about/venue/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/venue.html"}, + name='scipycon_venue'), + url(r'^%s/about/reaching/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/reaching.html"}, + name='scipycon_reaching'), + url(r'^%s/about/contact/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/contact.html"}, + name='scipycon_contact'), + url(r'^%s/about/day_zero/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/day_zero.html"}, + name='scipycon_day_zero'), + url(r'^%s/about/day_one/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/day_one.html"}, + name='scipycon_day_one'), + url(r'^%s/about/day_two/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/day_two.html"}, + name='scipycon_day_two'), + url(r'^%s/about/speakerinfo/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/speakerinfo.html"}, + name='scipycon_sinfo'), + url(r'^%s/about/city/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/city.html"}, + name='scipycon_city'), + url(r'^%s/talks-cfp/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "talk/talks-cfp.html"}, + name='scipycon_talks_cfp'), + url(r'^%s/talks-cfp/schedule/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "talk/schedule.html"}, + name='scipycon_schedule'), + url(r'^%s/talks-cfp/tutorial/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/tutorial.html"}, + name='scipycon_tutorial'), + url(r'^%s/talks-cfp/sprint/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "talk/sprint-schedule.html"}, + name='scipycon_sprint_schedule'), + url(r'^%s/talks-cfp/speakers/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "talk/speakers.html"}, + name='scipycon_speakers'), + url(r'^%s/publicity/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/publicity.html"}, + name='scipycon_publicity'), + url(r'^%s/about/fees/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/fees.html"}, + name='scipycon_fees'), + url(r'^%s/organizers/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/organizers.html"}, + name='scipycon_organizers'), + url(r'^%s/talks-cfp/conference/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "talk/conf_schedule.html"}, + name='scipycon_conference'), + url(r'^%s/tutorial/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/tutorial.html"}, + name='scipycon_tutorial'), + url(r'^%s/sprints/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/sprints.html"}, + name='scipycon_sprints'), + url(r'^%s/certificates/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/certificates.html"}, + name='scipycon_certificates'), + url(r'^%s/about/dates/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/important_dates.html"}, + name='scipycon_imp_dates'), + url(r'^%s/about/sponsors/$' % (SCOPE_ARG_PATTERN), + direct_to_template, {"template": "about/sponsors.html"}, + name='scipycon_sponsors'), + ) + +# Password reset +urlpatterns += patterns('django.contrib.auth.views', + url(r'^password-reset/$', 'password_reset', name='scipycon_password_reset'), + url(r'^password-reset-done/$', 'password_reset_done'), + url(r'^password-reset-confirm/(?P<uidb36>[-\w]*)/(?P<token>[-\w]*)$', 'password_reset_confirm'), + url(r'^password-reset-complete/$', 'password_reset_complete'), +) + +handler404 = 'project.scipycon.views.handler404' +handler500 = 'project.scipycon.views.handler404' + +# Serve static files in DEBUG = True mode +if settings.DEBUG: + urlpatterns += patterns('', + (r'^media/(?P<path>.*)$', 'django.views.static.serve', + {'document_root': settings.MEDIA_ROOT}), + (r'^static/(?P<path>.*)$', 'django.views.static.serve', + {'document_root': settings.STATIC_ROOT}), + ) |