X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/7f14cb747791cc03d44045e2a0fcfb73eed298e4..01eed1521a67afc04a8112b44ca4cd1c4a32cf00:/forum/urls.py diff --git a/forum/urls.py b/forum/urls.py index 2fea646..9ba2ebd 100644 --- a/forum/urls.py +++ b/forum/urls.py @@ -1,7 +1,9 @@ import startup import os.path +from forum import settings from django.conf.urls.defaults import * +from django.conf import settings as djsettings from django.contrib import admin from forum import views as app from forum.feed import RssLastestQuestionsFeed @@ -18,33 +20,46 @@ sitemaps = { } APP_PATH = os.path.dirname(__file__) -urlpatterns = patterns('', + +from forum.modules import get_modules_script + +module_patterns = get_modules_script('urls') + +urlpatterns = patterns('') + +for pattern_file in module_patterns: + pattern = getattr(pattern_file, 'urlpatterns', None) + if pattern: + urlpatterns += pattern + +urlpatterns += patterns('', url(r'^$', app.readers.index, name='index'), url(r'^sitemap.xml$', 'django.contrib.sitemaps.views.sitemap', {'sitemaps': sitemaps}, name='sitemap'), - #(r'^favicon\.ico$', 'django.views.generic.simple.redirect_to', {'url': '/media/images/favicon.ico'}), - #(r'^favicon\.gif$', 'django.views.generic.simple.redirect_to', {'url': '/media/images/favicon.gif'}), + (r'^favicon\.ico$', app.meta.favicon), - url(r'^m/(?P.*)$', 'django.views.static.serve', - {'document_root': os.path.join(APP_PATH,'skins').replace('\\','/')}, - name='osqa_media', - ), + + url(r'^m/(?P\w+)/media/(?P.*)$', app.meta.media , name='osqa_media'), url(r'^%s(?P.*)$' % _('upfiles/'), 'django.views.static.serve', {'document_root': os.path.join(APP_PATH,'upfiles').replace('\\','/')}, name='uploaded_file', ), - #url(r'^%s/$' % _('signin/'), 'django_authopenid.views.signin', name='signin'), - url(r'^%s$' % _('about/'), app.meta.about, name='about'), - url(r'^%s$' % _('faq/'), app.meta.faq, name='faq'), + + url(r'^%s$' % _('faq/'), app.meta.static, {'content': settings.FAQ_PAGE_TEXT, 'title': _('FAQ')}, name='faq'), + url(r'^%s$' % _('about/'), app.meta.static, {'content': settings.ABOUT_PAGE_TEXT, 'title': _('About')}, name='about'), + url(r'^%s$' % _('markdown_help/'), app.meta.markdown_help, name='markdown_help'), + url(r'^opensearch\.xml$', app.meta.opensearch, name='opensearch'), url(r'^%s$' % _('privacy/'), app.meta.privacy, name='privacy'), url(r'^%s$' % _('logout/'), app.meta.logout, name='logout'), url(r'^%s(?P\d+)/%s$' % (_('answers/'), _('edit/')), app.writers.edit_answer, name='edit_answer'), - url(r'^%s(?P\d+)/%s$' % (_('answers/'), _('revisions/')), app.readers.revisions, name='answer_revisions'), + url(r'^%s(?P\d+)/$' % _('revisions/'), app.readers.revisions, name='revisions'), url(r'^%s$' % _('questions/'), app.readers.questions, name='questions'), url(r'^%s%s$' % (_('questions/'), _('ask/')), app.writers.ask, name='ask'), + url(r'^%s%s$' % (_('questions/'), _('related_questions/')), app.commands.related_questions, name='related_questions'), + url(r'^%s%s$' % (_('questions/'), _('unanswered/')), app.readers.unanswered, name='unanswered'), url(r'^%s(?P\d+)/%s$' % (_('questions/'), _('edit/')), app.writers.edit_question, name='edit_question'), - url(r'^%s(?P\d+)/%s$' % (_('questions/'), _('close/')), app.commands.close, name='close'), - url(r'^%s(?P\d+)/%s$' % (_('questions/'), _('reopen/')), app.commands.reopen, name='reopen'), + url(r'^%s(?P\d+)/%s$' % (_('questions/'), _('close/')), app.commands.close, kwargs=dict(close=True), name='close'), + url(r'^%s(?P\d+)/%s$' % (_('questions/'), _('reopen/')), app.commands.close, kwargs=dict(close=False), name='reopen'), url(r'^%s(?P\d+)/%s$' % (_('questions/'), _('answer/')), app.writers.answer, name='answer'), url(r'^%s(?P\d+)/(?P[a-z]+)/' % _('vote/'), app.commands.vote_post, name='vote_post'), @@ -56,14 +71,15 @@ urlpatterns = patterns('', url(r'^%s(?P\d+)/' % _('flag/'), app.commands.flag_post, name='flag_post'), url(r'^%s(?P\d+)/' % _('delete/'), app.commands.delete_post, name='delete_post'), url(r'^%s(?P\d+)/$' % _('subscribe/'), app.commands.subscribe, name="subscribe"), + url(r'^%s' % _('matching_tags/'), app.commands.matching_tags, name='matching_tags'), + url(r'^%s(?P\d+)/' % _('node_markdown/'), app.commands.node_markdown, name='node_markdown'), + url(r'^%s(?P\d+)/' % _('convert/'), app.commands.convert_to_comment, name='convert_to_comment'), + url(r'^%s(?P\d+)/' % _('wikify/'), app.commands.wikify, name='wikify'), - url(r'^%s(?P\d+)/%s$' % (_('questions/'), _('revisions/')), app.readers.revisions, name='question_revisions'), - url(r'^%s$' % _('command/'), app.commands.ajax_command, name='call_ajax'), - - #place general question item in the end of other operations - url(r'^%s(?P\d+)/(?P[\w-]*)$' % _('question/'), app.readers.question, name='question'), + url(r'^%s(?P\d+)/(?P[\w-]*)$' % _('question/'), 'django.views.generic.simple.redirect_to', {'url': '/questions/%(id)s/%(slug)s'}), + url(r'^%s(?P\d+)/(?P[\w-]*)$' % _('questions/'), app.readers.question, name='question'), url(r'^%s$' % _('tags/'), app.readers.tags, name='tags'), - url(r'^%s(?P[^/]+)/$' % _('tags/'), app.readers.tag, name='tag_questions'), + url(r'^%s(?P.*)/$' % _('tags/'), app.readers.tag, name='tag_questions'), url(r'^%s%s(?P[^/]+)/$' % (_('mark-tag/'),_('interesting/')), app.commands.mark_tag, \ kwargs={'reason':'good','action':'add'}, \ @@ -80,10 +96,10 @@ urlpatterns = patterns('', url(r'^%s$' % _('users/'),app.users.users, name='users'), - url(r'^%s(?P\d+)/$' % _('moderate-user/'), app.users.moderate_user, name='moderate_user'), url(r'^%s(?P\d+)/%s$' % (_('users/'), _('edit/')), app.users.edit_user, name='edit_user'), - - url(r'^%s(?P\d+)/(?P.+)/%s$' % (_('users/'), _('subscriptions/')), app.users.user_subscriptions, name='user_subscriptions'), + url(r'^%s(?P\d+)/%s$' % (_('users/'), _('award/')), app.users.award_points, name='user_award_points'), + url(r'^%s(?P\d+)/%s(?P[a-z]+)/(?P[a-z]+)/$' % (_('users/'), _('powers/')), app.users.user_powers, name='user_powers'), + url(r'^%s(?P\d+)/%s$' % (_('users/'), _('subscriptions/')), app.users.user_subscriptions, name='user_subscriptions'), url(r'^%s(?P\d+)/(?P.+)/%s$' % (_('users/'), _('favorites/')), app.users.user_favorites, name='user_favorites'), url(r'^%s(?P\d+)/(?P.+)/%s$' % (_('users/'), _('reputation/')), app.users.user_reputation, name='user_reputation'), url(r'^%s(?P\d+)/(?P.+)/%s$' % (_('users/'), _('votes/')), app.users.user_votes, name='user_votes'), @@ -91,14 +107,13 @@ urlpatterns = patterns('', url(r'^%s(?P\d+)/(?P.+)/$' % _('users/'), app.users.user_stats, name='user_profile'), url(r'^%s$' % _('badges/'),app.meta.badges, name='badges'), - url(r'^%s(?P\d+)//*' % _('badges/'), app.meta.badge, name='badge'), - url(r'^%s%s$' % (_('messages/'), _('markread/')),app.commands.read_message, name='read_message'), + url(r'^%s(?P\d+)/(?P.+)/$' % _('badges/'), app.meta.badge, name='badge'), # (r'^admin/doc/' % _('admin/doc'), include('django.contrib.admindocs.urls')), url(r'^%s(.*)' % _('nimda/'), admin.site.root, name='osqa_admin'), url(r'^feeds/(?P.*)/$', 'django.contrib.syndication.views.feed', {'feed_dict': feeds}, name='feeds'), url(r'^%s$' % _('upload/'), app.writers.upload, name='upload'), url(r'^%s$' % _('search/'), app.readers.search, name='search'), - url(r'^%s$' % _('feedback/'), app.meta.feedback, name='feedback'), + url(r'^%s$' % _('contact/'), app.meta.feedback, name='feedback'), (r'^i18n/', include('django.conf.urls.i18n')), @@ -111,26 +126,22 @@ urlpatterns = patterns('', url(r'^%s%s(?P\d+)/(?P.+)/$' % (_('account/'), _('validate/')), app.auth.validate_email, name="auth_validate_email"), url(r'^%s%s$' % (_('account/'), _('tempsignin/')), app.auth.request_temp_login, name="auth_request_tempsignin"), url(r'^%s%s(?P\d+)/(?P.+)/$' % (_('account/'), _('tempsignin/')), app.auth.temp_signin, name="auth_tempsignin"), - url(r'^%s%s$' % (_('account/'), _('authsettings/')), app.auth.auth_settings, name='user_authsettings'), + url(r'^%s(?P\d+)/%s$' % (_('account/'), _('authsettings/')), app.auth.auth_settings, name='user_authsettings'), url(r'^%s%s(?P\d+)/%s$' % (_('account/'), _('providers/'), _('remove/')), app.auth.remove_external_provider, name='user_remove_external_provider'), url(r'^%s%s%s$' % (_('account/'), _('providers/'), _('add/')), app.auth.signin_page, name='user_add_external_provider'), - url(r'^%s$' % _('admin/'), app.admin.index, name="admin_index"), + url(r'^%s$' % _('admin/'), app.admin.dashboard, name="admin_index"), + url(r'^%s%s$' % (_('admin/'), _('switch_interface/')), app.admin.interface_switch, name="admin_switch_interface"), + url(r'^%s%s$' % (_('admin/'), _('statistics/')), app.admin.statistics, name="admin_statistics"), url(r'^%s%s$' % (_('admin/'), _('denormalize/')), app.admin.recalculate_denormalized, name="admin_denormalize"), url(r'^%s%s$' % (_('admin/'), _('go_bootstrap/')), app.admin.go_bootstrap, name="admin_go_bootstrap"), url(r'^%s%s$' % (_('admin/'), _('go_defaults/')), app.admin.go_defaults, name="admin_go_defaults"), - url(r'^%s(?P\w+)/$' % _('admin/'), app.admin.settings_set, name="admin_set"), + url(r'^%s%s(?P\w+)/(?P\w+)/$' % (_('admin/'), _('settings/')), app.admin.get_default, name="admin_default"), + url(r'^%s%s$' % (_('admin/'), _('maintenance/')), app.admin.maintenance, name="admin_maintenance"), + url(r'^%s%s$' % (_('admin/'), _('flagged_posts/')), app.admin.flagged_posts, name="admin_flagged_posts"), + + url(r'^%s%s(?P\w+)/$' % (_('admin/'), _('settings/')), app.admin.settings_set, name="admin_set"), url(r'^feeds/rss/$', RssLastestQuestionsFeed, name="latest_questions_feed"), ) - -from forum.modules import get_modules_script - -module_patterns = get_modules_script('urls') - -for pattern_file in module_patterns: - pattern = getattr(pattern_file, 'urlpatterns', None) - if pattern: - urlpatterns += pattern -