annotate config/routes.rb @ 1483:7e57ccd5f44b insider

Close obsolete branch insider
author Chris Cannam
date Sat, 10 Nov 2012 12:57:50 +0000
parents 5e80956cc792
children 3e52bc15dd67
rev   line source
Chris@0 1 ActionController::Routing::Routes.draw do |map|
Chris@0 2 # Add your own custom routes here.
Chris@0 3 # The priority is based upon order of creation: first created -> highest priority.
Chris@909 4
Chris@0 5 # Here's a sample route:
Chris@0 6 # map.connect 'products/:id', :controller => 'catalog', :action => 'view'
Chris@0 7 # Keep in mind you can assign values other than :controller and :action
Chris@0 8
Chris@0 9 map.home '', :controller => 'welcome'
Chris@909 10
Chris@0 11 map.signin 'login', :controller => 'account', :action => 'login'
Chris@0 12 map.signout 'logout', :controller => 'account', :action => 'logout'
Chris@909 13
Chris@0 14 map.connect 'roles/workflow/:id/:role_id/:tracker_id', :controller => 'roles', :action => 'workflow'
Chris@0 15 map.connect 'help/:ctrl/:page', :controller => 'help'
Chris@0 16
chris@37 17 map.with_options :controller => 'time_entry_reports', :action => 'report',:conditions => {:method => :get} do |time_report|
Chris@441 18 time_report.connect 'projects/:project_id/issues/:issue_id/time_entries/report'
Chris@441 19 time_report.connect 'projects/:project_id/issues/:issue_id/time_entries/report.:format'
Chris@441 20 time_report.connect 'projects/:project_id/time_entries/report'
Chris@441 21 time_report.connect 'projects/:project_id/time_entries/report.:format'
chris@37 22 time_report.connect 'time_entries/report'
chris@37 23 time_report.connect 'time_entries/report.:format'
Chris@0 24 end
chris@37 25
Chris@441 26 map.bulk_edit_time_entry 'time_entries/bulk_edit',
Chris@441 27 :controller => 'timelog', :action => 'bulk_edit', :conditions => { :method => :get }
Chris@441 28 map.bulk_update_time_entry 'time_entries/bulk_edit',
Chris@441 29 :controller => 'timelog', :action => 'bulk_update', :conditions => { :method => :post }
Chris@441 30 map.time_entries_context_menu '/time_entries/context_menu',
Chris@441 31 :controller => 'context_menus', :action => 'time_entries'
chris@37 32 # TODO: wasteful since this is also nested under issues, projects, and projects/issues
chris@37 33 map.resources :time_entries, :controller => 'timelog'
Chris@909 34
Chris@0 35 map.connect 'projects/:id/wiki', :controller => 'wikis', :action => 'edit', :conditions => {:method => :post}
Chris@0 36 map.connect 'projects/:id/wiki/destroy', :controller => 'wikis', :action => 'destroy', :conditions => {:method => :get}
Chris@0 37 map.connect 'projects/:id/wiki/destroy', :controller => 'wikis', :action => 'destroy', :conditions => {:method => :post}
Chris@909 38
Chris@0 39 map.with_options :controller => 'messages' do |messages_routes|
Chris@0 40 messages_routes.with_options :conditions => {:method => :get} do |messages_views|
Chris@0 41 messages_views.connect 'boards/:board_id/topics/new', :action => 'new'
Chris@0 42 messages_views.connect 'boards/:board_id/topics/:id', :action => 'show'
Chris@0 43 messages_views.connect 'boards/:board_id/topics/:id/edit', :action => 'edit'
Chris@0 44 end
Chris@0 45 messages_routes.with_options :conditions => {:method => :post} do |messages_actions|
Chris@0 46 messages_actions.connect 'boards/:board_id/topics/new', :action => 'new'
Chris@0 47 messages_actions.connect 'boards/:board_id/topics/:id/replies', :action => 'reply'
Chris@0 48 messages_actions.connect 'boards/:board_id/topics/:id/:action', :action => /edit|destroy/
Chris@0 49 end
Chris@0 50 end
Chris@909 51
Chris@0 52 map.with_options :controller => 'boards' do |board_routes|
Chris@0 53 board_routes.with_options :conditions => {:method => :get} do |board_views|
Chris@0 54 board_views.connect 'projects/:project_id/boards', :action => 'index'
Chris@0 55 board_views.connect 'projects/:project_id/boards/new', :action => 'new'
Chris@0 56 board_views.connect 'projects/:project_id/boards/:id', :action => 'show'
Chris@0 57 board_views.connect 'projects/:project_id/boards/:id.:format', :action => 'show'
Chris@0 58 board_views.connect 'projects/:project_id/boards/:id/edit', :action => 'edit'
Chris@0 59 end
Chris@0 60 board_routes.with_options :conditions => {:method => :post} do |board_actions|
Chris@0 61 board_actions.connect 'projects/:project_id/boards', :action => 'new'
Chris@0 62 board_actions.connect 'projects/:project_id/boards/:id/:action', :action => /edit|destroy/
Chris@0 63 end
Chris@0 64 end
Chris@909 65
Chris@0 66 map.with_options :controller => 'documents' do |document_routes|
Chris@0 67 document_routes.with_options :conditions => {:method => :get} do |document_views|
Chris@0 68 document_views.connect 'projects/:project_id/documents', :action => 'index'
Chris@0 69 document_views.connect 'projects/:project_id/documents/new', :action => 'new'
Chris@0 70 document_views.connect 'documents/:id', :action => 'show'
Chris@0 71 document_views.connect 'documents/:id/edit', :action => 'edit'
Chris@0 72 end
Chris@0 73 document_routes.with_options :conditions => {:method => :post} do |document_actions|
Chris@0 74 document_actions.connect 'projects/:project_id/documents', :action => 'new'
Chris@0 75 document_actions.connect 'documents/:id/:action', :action => /destroy|edit/
Chris@0 76 end
Chris@0 77 end
Chris@14 78
Chris@14 79 map.resources :issue_moves, :only => [:new, :create], :path_prefix => '/issues', :as => 'move'
Chris@909 80 map.resources :queries, :except => [:show]
chris@22 81
chris@22 82 # Misc issue routes. TODO: move into resources
Chris@909 83 map.auto_complete_issues '/issues/auto_complete', :controller => 'auto_completes', :action => 'issues', :conditions => { :method => :get }
chris@22 84 map.preview_issue '/issues/preview/:id', :controller => 'previews', :action => 'issue' # TODO: would look nicer as /issues/:id/preview
Chris@14 85 map.issues_context_menu '/issues/context_menu', :controller => 'context_menus', :action => 'issues'
Chris@14 86 map.issue_changes '/issues/changes', :controller => 'journals', :action => 'index'
chris@22 87 map.bulk_edit_issue 'issues/bulk_edit', :controller => 'issues', :action => 'bulk_edit', :conditions => { :method => :get }
chris@22 88 map.bulk_update_issue 'issues/bulk_edit', :controller => 'issues', :action => 'bulk_update', :conditions => { :method => :post }
chris@22 89 map.quoted_issue '/issues/:id/quoted', :controller => 'journals', :action => 'new', :id => /\d+/, :conditions => { :method => :post }
chris@22 90 map.connect '/issues/:id/destroy', :controller => 'issues', :action => 'destroy', :conditions => { :method => :post } # legacy
chris@22 91
Chris@441 92 map.with_options :controller => 'gantts', :action => 'show' do |gantts_routes|
Chris@441 93 gantts_routes.connect '/projects/:project_id/issues/gantt'
Chris@441 94 gantts_routes.connect '/projects/:project_id/issues/gantt.:format'
Chris@441 95 gantts_routes.connect '/issues/gantt.:format'
Chris@441 96 end
Chris@909 97
Chris@441 98 map.with_options :controller => 'calendars', :action => 'show' do |calendars_routes|
Chris@441 99 calendars_routes.connect '/projects/:project_id/issues/calendar'
Chris@441 100 calendars_routes.connect '/issues/calendar'
Chris@441 101 end
chris@22 102
chris@22 103 map.with_options :controller => 'reports', :conditions => {:method => :get} do |reports|
chris@22 104 reports.connect 'projects/:id/issues/report', :action => 'issue_report'
chris@22 105 reports.connect 'projects/:id/issues/report/:detail', :action => 'issue_report_details'
chris@22 106 end
chris@22 107
chris@22 108 # Following two routes conflict with the resources because #index allows POST
chris@22 109 map.connect '/issues', :controller => 'issues', :action => 'index', :conditions => { :method => :post }
chris@22 110 map.connect '/issues/create', :controller => 'issues', :action => 'index', :conditions => { :method => :post }
Chris@909 111
chris@37 112 map.resources :issues, :member => { :edit => :post }, :collection => {} do |issues|
chris@37 113 issues.resources :time_entries, :controller => 'timelog'
Chris@909 114 issues.resources :relations, :shallow => true, :controller => 'issue_relations', :only => [:index, :show, :create, :destroy]
chris@37 115 end
Chris@909 116
chris@37 117 map.resources :issues, :path_prefix => '/projects/:project_id', :collection => { :create => :post } do |issues|
chris@37 118 issues.resources :time_entries, :controller => 'timelog'
chris@37 119 end
Chris@14 120
Chris@0 121 map.connect 'projects/:id/members/new', :controller => 'members', :action => 'new'
chris@37 122
Chris@0 123 map.with_options :controller => 'users' do |users|
chris@37 124 users.connect 'users/:id/edit/:tab', :action => 'edit', :tab => nil, :conditions => {:method => :get}
Chris@909 125
Chris@0 126 users.with_options :conditions => {:method => :post} do |user_actions|
Chris@0 127 user_actions.connect 'users/:id/memberships', :action => 'edit_membership'
Chris@0 128 user_actions.connect 'users/:id/memberships/:membership_id', :action => 'edit_membership'
Chris@0 129 user_actions.connect 'users/:id/memberships/:membership_id/destroy', :action => 'destroy_membership'
Chris@0 130 end
Chris@0 131 end
Chris@0 132
chris@37 133 map.resources :users, :member => {
chris@37 134 :edit_membership => :post,
chris@37 135 :destroy_membership => :post
Chris@128 136 }
chris@37 137
chris@22 138 # For nice "roadmap" in the url for the index action
chris@22 139 map.connect 'projects/:project_id/roadmap', :controller => 'versions', :action => 'index'
Chris@0 140
chris@37 141 map.all_news 'news', :controller => 'news', :action => 'index'
chris@37 142 map.formatted_all_news 'news.:format', :controller => 'news', :action => 'index'
chris@37 143 map.preview_news '/news/preview', :controller => 'previews', :action => 'news'
chris@37 144 map.connect 'news/:id/comments', :controller => 'comments', :action => 'create', :conditions => {:method => :post}
chris@37 145 map.connect 'news/:id/comments/:comment_id', :controller => 'comments', :action => 'destroy', :conditions => {:method => :delete}
chris@37 146
chris@22 147 map.resources :projects, :member => {
chris@22 148 :copy => [:get, :post],
chris@22 149 :settings => :get,
chris@22 150 :modules => :post,
chris@351 151 :overview => :post,
chris@22 152 :archive => :post,
chris@22 153 :unarchive => :post
chris@22 154 } do |project|
chris@22 155 project.resource :project_enumerations, :as => 'enumerations', :only => [:update, :destroy]
chris@22 156 project.resources :files, :only => [:index, :new, :create]
Chris@909 157 project.resources :versions, :shallow => true, :collection => {:close_completed => :put}, :member => {:status_by => :post}
chris@37 158 project.resources :news, :shallow => true
chris@37 159 project.resources :time_entries, :controller => 'timelog', :path_prefix => 'projects/:project_id'
Chris@909 160 project.resources :queries, :only => [:new, :create]
Chris@909 161 project.resources :issue_categories, :shallow => true
chris@37 162
chris@37 163 project.wiki_start_page 'wiki', :controller => 'wiki', :action => 'show', :conditions => {:method => :get}
chris@37 164 project.wiki_index 'wiki/index', :controller => 'wiki', :action => 'index', :conditions => {:method => :get}
chris@37 165 project.wiki_diff 'wiki/:id/diff/:version', :controller => 'wiki', :action => 'diff', :version => nil
chris@37 166 project.wiki_diff 'wiki/:id/diff/:version/vs/:version_from', :controller => 'wiki', :action => 'diff'
chris@37 167 project.wiki_annotate 'wiki/:id/annotate/:version', :controller => 'wiki', :action => 'annotate'
chris@37 168 project.resources :wiki, :except => [:new, :create], :member => {
chris@37 169 :rename => [:get, :post],
chris@37 170 :history => :get,
chris@37 171 :preview => :any,
chris@37 172 :protect => :post,
chris@37 173 :add_attachment => :post
chris@37 174 }, :collection => {
chris@37 175 :export => :get,
chris@37 176 :date_index => :get
chris@37 177 }
chris@37 178
chris@22 179 end
Chris@0 180
chris@22 181 # Destroy uses a get request to prompt the user before the actual DELETE request
chris@22 182 map.project_destroy_confirm 'projects/:id/destroy', :controller => 'projects', :action => 'destroy', :conditions => {:method => :get}
chris@22 183
chris@22 184 # TODO: port to be part of the resources route(s)
chris@22 185 map.with_options :controller => 'projects' do |project_mapper|
chris@22 186 project_mapper.with_options :conditions => {:method => :get} do |project_views|
chris@22 187 project_views.connect 'projects/:id/settings/:tab', :controller => 'projects', :action => 'settings'
chris@22 188 project_views.connect 'projects/:project_id/issues/:copy_from/copy', :controller => 'issues', :action => 'new'
Chris@0 189 end
Chris@0 190 end
Chris@909 191
chris@22 192 map.with_options :controller => 'activities', :action => 'index', :conditions => {:method => :get} do |activity|
chris@22 193 activity.connect 'projects/:id/activity'
chris@22 194 activity.connect 'projects/:id/activity.:format'
chris@22 195 activity.connect 'activity', :id => nil
chris@22 196 activity.connect 'activity.:format', :id => nil
Chris@0 197 end
chris@22 198
Chris@0 199 map.with_options :controller => 'repositories' do |repositories|
Chris@0 200 repositories.with_options :conditions => {:method => :get} do |repository_views|
Chris@0 201 repository_views.connect 'projects/:id/repository', :action => 'show'
Chris@0 202 repository_views.connect 'projects/:id/repository/edit', :action => 'edit'
Chris@0 203 repository_views.connect 'projects/:id/repository/statistics', :action => 'stats'
Chris@0 204 repository_views.connect 'projects/:id/repository/revisions', :action => 'revisions'
Chris@0 205 repository_views.connect 'projects/:id/repository/revisions.:format', :action => 'revisions'
Chris@0 206 repository_views.connect 'projects/:id/repository/revisions/:rev', :action => 'revision'
Chris@0 207 repository_views.connect 'projects/:id/repository/revisions/:rev/diff', :action => 'diff'
Chris@0 208 repository_views.connect 'projects/:id/repository/revisions/:rev/diff.:format', :action => 'diff'
Chris@0 209 repository_views.connect 'projects/:id/repository/revisions/:rev/raw/*path', :action => 'entry', :format => 'raw', :requirements => { :rev => /[a-z0-9\.\-_]+/ }
Chris@0 210 repository_views.connect 'projects/:id/repository/revisions/:rev/:action/*path', :requirements => { :rev => /[a-z0-9\.\-_]+/ }
Chris@0 211 repository_views.connect 'projects/:id/repository/raw/*path', :action => 'entry', :format => 'raw'
Chris@0 212 # TODO: why the following route is required?
Chris@0 213 repository_views.connect 'projects/:id/repository/entry/*path', :action => 'entry'
Chris@0 214 repository_views.connect 'projects/:id/repository/:action/*path'
Chris@0 215 end
Chris@909 216
Chris@0 217 repositories.connect 'projects/:id/repository/:action', :conditions => {:method => :post}
Chris@0 218 end
Chris@0 219
Chris@909 220 map.resources :attachments, :only => [:show, :destroy]
Chris@909 221 # additional routes for having the file name at the end of url
Chris@0 222 map.connect 'attachments/:id/:filename', :controller => 'attachments', :action => 'show', :id => /\d+/, :filename => /.*/
Chris@0 223 map.connect 'attachments/download/:id/:filename', :controller => 'attachments', :action => 'download', :id => /\d+/, :filename => /.*/
Chris@909 224
Chris@909 225 map.resources :groups, :member => {:autocomplete_for_user => :get}
Chris@909 226 map.group_users 'groups/:id/users', :controller => 'groups', :action => 'add_users', :id => /\d+/, :conditions => {:method => :post}
Chris@909 227 map.group_user 'groups/:id/users/:user_id', :controller => 'groups', :action => 'remove_user', :id => /\d+/, :conditions => {:method => :delete}
Chris@909 228
Chris@909 229 map.resources :trackers, :except => :show
Chris@909 230 map.resources :issue_statuses, :except => :show, :collection => {:update_issue_done_ratio => :post}
Chris@909 231
Chris@0 232 #left old routes at the bottom for backwards compat
Chris@0 233 map.connect 'projects/:project_id/issues/:action', :controller => 'issues'
chris@493 234 map.connect 'projects/:project_id/members/:action', :controller => 'members'
Chris@0 235 map.connect 'projects/:project_id/documents/:action', :controller => 'documents'
Chris@0 236 map.connect 'projects/:project_id/boards/:action/:id', :controller => 'boards'
Chris@0 237 map.connect 'boards/:board_id/topics/:action/:id', :controller => 'messages'
Chris@0 238 map.connect 'wiki/:id/:page/:action', :page => nil, :controller => 'wiki'
Chris@909 239 map.connect 'projects/:project_id/news/:action', :controller => 'news'
Chris@0 240 map.connect 'projects/:project_id/timelog/:action/:id', :controller => 'timelog', :project_id => /.+/
Chris@0 241 map.with_options :controller => 'repositories' do |omap|
Chris@0 242 omap.repositories_show 'repositories/browse/:id/*path', :action => 'browse'
Chris@0 243 omap.repositories_changes 'repositories/changes/:id/*path', :action => 'changes'
Chris@0 244 omap.repositories_diff 'repositories/diff/:id/*path', :action => 'diff'
Chris@0 245 omap.repositories_entry 'repositories/entry/:id/*path', :action => 'entry'
Chris@0 246 omap.repositories_entry 'repositories/annotate/:id/*path', :action => 'annotate'
Chris@0 247 omap.connect 'repositories/revision/:id/:rev', :action => 'revision'
Chris@0 248 end
Chris@909 249
Chris@0 250 map.with_options :controller => 'sys' do |sys|
Chris@0 251 sys.connect 'sys/projects.:format', :action => 'projects', :conditions => {:method => :get}
Chris@0 252 sys.connect 'sys/projects/:id/repository.:format', :action => 'create_project_repository', :conditions => {:method => :post}
chris@437 253 sys.connect 'sys/projects/:id/external_repository.:format', :action => 'get_external_repo_url', :conditions => {:method => :get}
chris@218 254 sys.connect 'sys/projects/:id/embedded.:format', :action => 'set_embedded_active', :conditions => { :method => :post }
chris@437 255 sys.connect 'sys/projects/:id/repository_cache.:format', :action => 'clear_repository_cache', :conditions => {:method => :post}
Chris@0 256 end
Chris@909 257
Chris@0 258 # Install the default route as the lowest priority.
Chris@0 259 map.connect ':controller/:action/:id'
Chris@0 260 map.connect 'robots.txt', :controller => 'welcome', :action => 'robots'
Chris@0 261 # Used for OpenID
Chris@0 262 map.root :controller => 'account', :action => 'login'
Chris@0 263 end