diff options
-rw-r--r-- | config/routes.rb | 81 |
1 files changed, 81 insertions, 0 deletions
diff --git a/config/routes.rb b/config/routes.rb index 207dc13c8..5b736fd2c 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -10,49 +10,80 @@ $alaveteli_route_extensions.each do |f| end Alaveteli::Application.routes.draw do + #### General contoller match '/' => 'general#frontpage', :as => :frontpage match '/blog' => 'general#blog', :as => :blog match '/stylesheets/custom.css' => 'general#custom_css', :as => :custom_css match '/search' => 'general#search_redirect', :as => :search_redirect match '/search/all' => 'general#search_redirect', :as => :search_redirect + # XXX combined is the search query, and then if sorted a "/newest" at the end. + # Couldn't find a way to do this in routes which also picked up multiple other slashes + # and dots and other characters that can appear in search query. So we sort it all + # out in the controller. match '/search/*combined/all' => 'general#search', :as => :search_general, :view => 'all' match '/search(/*combined)' => 'general#search', :as => :search_general match '/advancedsearch' => 'general#search_redirect', :as => :advanced_search, :advanced => true + match '/random' => 'general#random_request', :as => :random_request + ##### + + ##### Request controller match '/list/recent' => 'request#list', :as => :request_list_recent, :view => 'recent' match '/list/all' => 'request#list', :as => :request_list_all, :view => 'all' match '/list/successful' => 'request#list', :as => :request_list_successful, :view => 'successful' match '/list/unsuccessful' => 'request#list', :as => :request_list_unsuccessful, :view => 'unsuccessful' match '/list/awaiting' => 'request#list', :as => :request_list_awaiting, :view => 'awaiting' match '/list' => 'request#list', :as => :request_list + match '/select_authority' => 'request#select_authority', :as => :select_authority + match '/new' => 'request#new', :as => :new_request match '/new/:url_name' => 'request#new', :as => :new_request_to_body + match '/request/search_ahead' => 'request#search_typeahead', :as => :search_ahead + match '/request/:url_title' => 'request#show', :as => :show_request match '/request/:url_title/new' => 'request#show', :as => :show_new_request match '/details/request/:url_title' => 'request#details', :as => :details_request match '/similar/request/:url_title' => 'request#similar', :as => :similar_request + match '/request/:id/describe' => 'request#describe_state', :as => :describe_state match '/request/:id/response' => 'request#show_response', :as => :show_response_no_followup match '/request/:id/response/:incoming_message_id' => 'request#show_response', :as => :show_response match '/request/:id/response/:incoming_message_id/attach/html/:part/*file_name' => 'request#get_attachment_as_html', :as => :get_attachment_as_html match '/request/:id/response/:incoming_message_id/attach/:part(/*file_name)' => 'request#get_attachment', :as => :get_attachment + match '/request_event/:info_request_event_id' => 'request#show_request_event', :as => :info_request_event + match '/upload/request/:url_title' => 'request#upload_response', :as => :upload_response match '/request/:url_title/download' => 'request#download_entire_request', :as => :download_entire_request + + # It would be nice to add :conditions => { :method => :post } to this next one, + # because it ought not really to be available as a GET request since it changes + # the server state. Unfortunately this doesn’t play well with the PostRedirect + # mechanism, which assumes all post-login actions are available via GET, so we + # refrain. match '/request/:url_title/report' => 'request#report_request', :as => :report + #### + + #### User controller + # Use /profile for things to do with the currently signed in user. + # Use /user/XXXX for things that anyone can see about that user. + # Note that /profile isn't indexed by search (see robots.txt) match '/profile/sign_in' => 'user#signin', :as => :signin match '/profile/sign_up' => 'user#signup', :as => :signup match '/profile/sign_out' => 'user#signout', :as => :signout + match '/c/:email_token' => 'user#confirm', :as => :confirm match '/user/:url_name' => 'user#show', :as => :show_user match '/user/:url_name/profile' => 'user#show', :as => :show_user_profile, :view => 'profile' match '/user/:url_name/requests' => 'user#show', :as => :show_user_requests, :view => 'requests' match '/user/:url_name/wall' => 'user#wall', :as => :show_user_wall match '/user/contact/:id' => 'user#contact', :as => :contact_user + match '/profile/change_password' => 'user#signchangepassword', :as => :signchangepassword match '/profile/change_email' => 'user#signchangeemail', :as => :signchangeemail + match '/profile/set_photo' => 'user#set_profile_photo', :as => :set_profile_photo match '/profile/clear_photo' => 'user#clear_profile_photo', :as => :clear_profile_photo match '/user/:url_name/photo.png' => 'user#get_profile_photo', :as => :get_profile_photo @@ -60,6 +91,9 @@ Alaveteli::Application.routes.draw do match '/profile/set_about_me' => 'user#set_profile_about_me', :as => :set_profile_about_me match '/profile/set_receive_alerts' => 'user#set_receive_email_alerts', :as => :set_receive_email_alerts match '/profile/river' => 'user#river', :as => :river + #### + + #### PublicBody controller match '/body/search_ahead' => 'public_body#search_typeahead', :as => :search_ahead_bodies match '/body' => 'public_body#list', :as => :list_public_bodies match '/body/list/all' => 'public_body#list', :as => :list_public_bodies_default @@ -74,17 +108,34 @@ Alaveteli::Application.routes.draw do match '/body/:url_name/view_email' => 'public_body#view_email', :as => :view_public_body_email match '/body/:url_name/:tag' => 'public_body#show', :as => :show_public_body_tag match '/body/:url_name/:tag/:view' => 'public_body#show', :as => :show_public_body_tag_view + #### + + #### Comment controller match '/annotate/request/:url_title' => 'comment#new', :as => :new_comment, :type => 'request' + #### + + #### Services controller match '/country_message' => 'services#other_country_message', :as => :other_country_message match '/hidden_user_explanation' => 'services#hidden_user_explanation', :as => :hidden_user_explanation + #### + + #### Track controller + # /track/ is for setting up an email alert for the item + # /feed/ is a direct RSS feed of the item match '/:feed/request/:url_title' => 'track#track_request', :as => :track_request, :feed => /(track|feed)/ match '/:feed/list/:view' => 'track#track_list', :as => :track_list, :view => nil, :feed => /(track|feed)/ match '/:feed/body/:url_name' => 'track#track_public_body', :as => :track_public_body, :feed => /(track|feed)/ match '/:feed/user/:url_name' => 'track#track_user', :as => :track_user, :feed => /(track|feed)/ + # XXX must be better way of getting dots and slashes in search queries to work than this *query_array + # Also, the :format doesn't work. See hacky code in the controller that makes up for this. match '/:feed/search/*query_array' => 'track#track_search_query', :as => :track_search, :feed => /(track|feed)/ + match '/track/update/:track_id' => 'track#update', :as => :update match '/track/delete_all_type' => 'track#delete_all_type', :as => :delete_all_type match '/track/feed/:track_id' => 'track#atom_feed', :as => :atom_feed + #### + + #### Help controller match '/help/unhappy/:url_title' => 'help#unhappy', :as => :help_unhappy match '/help/about' => 'help#about', :as => :help_about match '/help/alaveteli' => 'help#alaveteli', :as => :help_alaveteli @@ -95,10 +146,19 @@ Alaveteli::Application.routes.draw do match '/help/api' => 'help#api', :as => :help_api match '/help/credits' => 'help#credits', :as => :help_credits match '/help/:action' => 'help#action', :as => :help_general + #### + + #### Holiday controller match '/due_date/:holiday' => 'holiday#due_date', :as => :due_date + #### + + #### RequestGame controller match '/categorise/play' => 'request_game#play', :as => :play match '/categorise/request/:url_title' => 'request_game#show', :as => :request match '/categorise/stop' => 'request_game#stop', :as => :stop + #### + + #### AdminPublicBody controller match '/admin/missing_scheme' => 'admin_public_body#missing_scheme', :as => :admin_body_missing match '/admin/body' => 'admin_public_body#index', :as => :admin_body_index match '/admin/body/list' => 'admin_public_body#list', :as => :admin_body_list @@ -111,10 +171,16 @@ Alaveteli::Application.routes.draw do match '/admin/body/destroy/:id' => 'admin_public_body#destroy', :as => :admin_body_destroy match '/admin/body/import_csv' => 'admin_public_body#import_csv', :as => :admin_body_import_csv match '/admin/body/mass_tag_add' => 'admin_public_body#mass_tag_add', :as => :admin_body_mass_tag_add + #### + + #### AdminGeneral controller match '/admin' => 'admin_general#index', :as => :admin_general_index match '/admin/timeline' => 'admin_general#timeline', :as => :admin_timeline match '/admin/debug' => 'admin_general#debug', :as => :admin_debug match '/admin/stats' => 'admin_general#stats', :as => :admin_stats + #### + + #### AdminRequest controller match '/admin/unclassified' => 'admin_request#list_old_unclassified', :as => :admin_request_list_old_unclassified match '/admin/request' => 'admin_request#index', :as => :admin_request_index match '/admin/request/list' => 'admin_request#list', :as => :admin_request_list @@ -136,6 +202,9 @@ Alaveteli::Application.routes.draw do match '/admin/request/download_raw_email/:id' => 'admin_request#download_raw_email', :as => :admin_request_download_raw_email match '/admin/request/mark_event_as_clarification' => 'admin_request#mark_event_as_clarification', :as => :admin_request_clarification match '/admin/request/hide/:id' => 'admin_request#hide_request', :as => :admin_request_hide + #### + + #### AdminUser controller match '/admin/user' => 'admin_user#index', :as => :admin_user_index match '/admin/user/list' => 'admin_user#list', :as => :admin_user_list match '/admin/user/banned' => 'admin_user#list_banned', :as => :admin_user_list_banned @@ -147,16 +216,28 @@ Alaveteli::Application.routes.draw do match '/admin/user/destroy_track' => 'admin_user#destroy_track', :as => :admin_user_destroy_track match '/admin/user/login_as/:id' => 'admin_user#login_as', :as => :admin_user_login_as match '/admin/user/clear_profile_photo/:id' => 'admin_user#clear_profile_photo', :as => :admin_clear_profile_photo + #### + + #### AdminTrack controller match '/admin/track/list' => 'admin_track#list', :as => :admin_track_list + #### + + #### AdminCensorRule controller match '/admin/censor/new' => 'admin_censor_rule#new', :as => :admin_rule_new match '/admin/censor/create' => 'admin_censor_rule#create', :as => :admin_rule_create match '/admin/censor/edit/:id' => 'admin_censor_rule#edit', :as => :admin_rule_edit match '/admin/censor/update/:id' => 'admin_censor_rule#update', :as => :admin_rule_update match '/admin/censor/destroy/:censor_rule_id' => 'admin_censor_rule#destroy', :as => :admin_rule_destroy + #### + + #### Api controller match '/api/v2/request.json' => 'api#create_request', :as => :api_create_request, :via => :post + match '/api/v2/request/:id.json' => 'api#show_request', :as => :api_show_request, :via => :get match '/api/v2/request/:id.json' => 'api#add_correspondence', :as => :api_add_correspondence, :via => :post + match '/api/v2/body/:id/request_events.:feed_type' => 'api#body_request_events', :as => :api_body_request_events, :feed_type => '^(json|atom)$' + #### filter :conditionallyprependlocale end |