annotate config/routes.rb @ 850:e9e53db0c93a bug_213

Close obsolete branch bug_213
author Chris Cannam
date Sat, 13 Aug 2011 14:51:48 +0100
parents 7a2bb9c5fb34
children 5e80956cc792
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@0 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@0 10
Chris@0 11 map.signin 'login', :controller => 'account', :action => 'login'
Chris@0 12 map.signout 'logout', :controller => 'account', :action => 'logout'
Chris@0 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@0 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@0 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@0 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@0 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@22 80
chris@22 81 # Misc issue routes. TODO: move into resources
Chris@14 82 map.auto_complete_issues '/issues/auto_complete', :controller => 'auto_completes', :action => 'issues'
chris@22 83 map.preview_issue '/issues/preview/:id', :controller => 'previews', :action => 'issue' # TODO: would look nicer as /issues/:id/preview
Chris@14 84 map.issues_context_menu '/issues/context_menu', :controller => 'context_menus', :action => 'issues'
Chris@14 85 map.issue_changes '/issues/changes', :controller => 'journals', :action => 'index'
chris@22 86 map.bulk_edit_issue 'issues/bulk_edit', :controller => 'issues', :action => 'bulk_edit', :conditions => { :method => :get }
chris@22 87 map.bulk_update_issue 'issues/bulk_edit', :controller => 'issues', :action => 'bulk_update', :conditions => { :method => :post }
chris@22 88 map.quoted_issue '/issues/:id/quoted', :controller => 'journals', :action => 'new', :id => /\d+/, :conditions => { :method => :post }
chris@22 89 map.connect '/issues/:id/destroy', :controller => 'issues', :action => 'destroy', :conditions => { :method => :post } # legacy
chris@22 90
Chris@441 91 map.with_options :controller => 'gantts', :action => 'show' do |gantts_routes|
Chris@441 92 gantts_routes.connect '/projects/:project_id/issues/gantt'
Chris@441 93 gantts_routes.connect '/projects/:project_id/issues/gantt.:format'
Chris@441 94 gantts_routes.connect '/issues/gantt.:format'
Chris@441 95 end
Chris@441 96
Chris@441 97 map.with_options :controller => 'calendars', :action => 'show' do |calendars_routes|
Chris@441 98 calendars_routes.connect '/projects/:project_id/issues/calendar'
Chris@441 99 calendars_routes.connect '/issues/calendar'
Chris@441 100 end
chris@22 101
chris@22 102 map.with_options :controller => 'reports', :conditions => {:method => :get} do |reports|
chris@22 103 reports.connect 'projects/:id/issues/report', :action => 'issue_report'
chris@22 104 reports.connect 'projects/:id/issues/report/:detail', :action => 'issue_report_details'
chris@22 105 end
chris@22 106
chris@22 107 # Following two routes conflict with the resources because #index allows POST
chris@22 108 map.connect '/issues', :controller => 'issues', :action => 'index', :conditions => { :method => :post }
chris@22 109 map.connect '/issues/create', :controller => 'issues', :action => 'index', :conditions => { :method => :post }
Chris@0 110
chris@37 111 map.resources :issues, :member => { :edit => :post }, :collection => {} do |issues|
chris@37 112 issues.resources :time_entries, :controller => 'timelog'
chris@37 113 end
chris@37 114
chris@37 115 map.resources :issues, :path_prefix => '/projects/:project_id', :collection => { :create => :post } do |issues|
chris@37 116 issues.resources :time_entries, :controller => 'timelog'
chris@37 117 end
Chris@14 118
Chris@0 119 map.with_options :controller => 'issue_relations', :conditions => {:method => :post} do |relations|
Chris@0 120 relations.connect 'issues/:issue_id/relations/:id', :action => 'new'
Chris@0 121 relations.connect 'issues/:issue_id/relations/:id/destroy', :action => 'destroy'
Chris@0 122 end
chris@22 123
Chris@0 124 map.connect 'projects/:id/members/new', :controller => 'members', :action => 'new'
chris@37 125
Chris@0 126 map.with_options :controller => 'users' do |users|
chris@37 127 users.connect 'users/:id/edit/:tab', :action => 'edit', :tab => nil, :conditions => {:method => :get}
chris@37 128
Chris@0 129 users.with_options :conditions => {:method => :post} do |user_actions|
Chris@0 130 user_actions.connect 'users/:id/memberships', :action => 'edit_membership'
Chris@0 131 user_actions.connect 'users/:id/memberships/:membership_id', :action => 'edit_membership'
Chris@0 132 user_actions.connect 'users/:id/memberships/:membership_id/destroy', :action => 'destroy_membership'
Chris@0 133 end
Chris@0 134 end
Chris@0 135
chris@37 136 map.resources :users, :member => {
chris@37 137 :edit_membership => :post,
chris@37 138 :destroy_membership => :post
Chris@128 139 }
chris@37 140
chris@22 141 # For nice "roadmap" in the url for the index action
chris@22 142 map.connect 'projects/:project_id/roadmap', :controller => 'versions', :action => 'index'
Chris@0 143
chris@37 144 map.all_news 'news', :controller => 'news', :action => 'index'
chris@37 145 map.formatted_all_news 'news.:format', :controller => 'news', :action => 'index'
chris@37 146 map.preview_news '/news/preview', :controller => 'previews', :action => 'news'
chris@37 147 map.connect 'news/:id/comments', :controller => 'comments', :action => 'create', :conditions => {:method => :post}
chris@37 148 map.connect 'news/:id/comments/:comment_id', :controller => 'comments', :action => 'destroy', :conditions => {:method => :delete}
chris@37 149
chris@22 150 map.resources :projects, :member => {
chris@22 151 :copy => [:get, :post],
chris@22 152 :settings => :get,
chris@22 153 :modules => :post,
chris@351 154 :overview => :post,
chris@22 155 :archive => :post,
chris@22 156 :unarchive => :post
chris@22 157 } do |project|
chris@22 158 project.resource :project_enumerations, :as => 'enumerations', :only => [:update, :destroy]
chris@22 159 project.resources :files, :only => [:index, :new, :create]
chris@22 160 project.resources :versions, :collection => {:close_completed => :put}, :member => {:status_by => :post}
chris@37 161 project.resources :news, :shallow => true
chris@37 162 project.resources :time_entries, :controller => 'timelog', :path_prefix => 'projects/:project_id'
chris@37 163
chris@37 164 project.wiki_start_page 'wiki', :controller => 'wiki', :action => 'show', :conditions => {:method => :get}
chris@37 165 project.wiki_index 'wiki/index', :controller => 'wiki', :action => 'index', :conditions => {:method => :get}
chris@37 166 project.wiki_diff 'wiki/:id/diff/:version', :controller => 'wiki', :action => 'diff', :version => nil
chris@37 167 project.wiki_diff 'wiki/:id/diff/:version/vs/:version_from', :controller => 'wiki', :action => 'diff'
chris@37 168 project.wiki_annotate 'wiki/:id/annotate/:version', :controller => 'wiki', :action => 'annotate'
chris@37 169 project.resources :wiki, :except => [:new, :create], :member => {
chris@37 170 :rename => [:get, :post],
chris@37 171 :history => :get,
chris@37 172 :preview => :any,
chris@37 173 :protect => :post,
chris@37 174 :add_attachment => :post
chris@37 175 }, :collection => {
chris@37 176 :export => :get,
chris@37 177 :date_index => :get
chris@37 178 }
chris@37 179
chris@22 180 end
Chris@0 181
chris@22 182 # Destroy uses a get request to prompt the user before the actual DELETE request
chris@22 183 map.project_destroy_confirm 'projects/:id/destroy', :controller => 'projects', :action => 'destroy', :conditions => {:method => :get}
chris@22 184
chris@22 185 # TODO: port to be part of the resources route(s)
chris@22 186 map.with_options :controller => 'projects' do |project_mapper|
chris@22 187 project_mapper.with_options :conditions => {:method => :get} do |project_views|
chris@22 188 project_views.connect 'projects/:id/settings/:tab', :controller => 'projects', :action => 'settings'
chris@22 189 project_views.connect 'projects/:project_id/issues/:copy_from/copy', :controller => 'issues', :action => 'new'
Chris@0 190 end
Chris@0 191 end
Chris@0 192
chris@22 193 map.with_options :controller => 'activities', :action => 'index', :conditions => {:method => :get} do |activity|
chris@22 194 activity.connect 'projects/:id/activity'
chris@22 195 activity.connect 'projects/:id/activity.:format'
chris@22 196 activity.connect 'activity', :id => nil
chris@22 197 activity.connect 'activity.:format', :id => nil
Chris@0 198 end
chris@22 199
chris@22 200
Chris@0 201 map.with_options :controller => 'issue_categories' do |categories|
Chris@0 202 categories.connect 'projects/:project_id/issue_categories/new', :action => 'new'
Chris@0 203 end
Chris@0 204
Chris@0 205 map.with_options :controller => 'repositories' do |repositories|
Chris@0 206 repositories.with_options :conditions => {:method => :get} do |repository_views|
Chris@0 207 repository_views.connect 'projects/:id/repository', :action => 'show'
Chris@0 208 repository_views.connect 'projects/:id/repository/edit', :action => 'edit'
Chris@0 209 repository_views.connect 'projects/:id/repository/statistics', :action => 'stats'
Chris@0 210 repository_views.connect 'projects/:id/repository/revisions', :action => 'revisions'
Chris@0 211 repository_views.connect 'projects/:id/repository/revisions.:format', :action => 'revisions'
Chris@0 212 repository_views.connect 'projects/:id/repository/revisions/:rev', :action => 'revision'
Chris@0 213 repository_views.connect 'projects/:id/repository/revisions/:rev/diff', :action => 'diff'
Chris@0 214 repository_views.connect 'projects/:id/repository/revisions/:rev/diff.:format', :action => 'diff'
Chris@0 215 repository_views.connect 'projects/:id/repository/revisions/:rev/raw/*path', :action => 'entry', :format => 'raw', :requirements => { :rev => /[a-z0-9\.\-_]+/ }
Chris@0 216 repository_views.connect 'projects/:id/repository/revisions/:rev/:action/*path', :requirements => { :rev => /[a-z0-9\.\-_]+/ }
Chris@0 217 repository_views.connect 'projects/:id/repository/raw/*path', :action => 'entry', :format => 'raw'
Chris@0 218 # TODO: why the following route is required?
Chris@0 219 repository_views.connect 'projects/:id/repository/entry/*path', :action => 'entry'
Chris@0 220 repository_views.connect 'projects/:id/repository/:action/*path'
Chris@0 221 end
Chris@0 222
Chris@0 223 repositories.connect 'projects/:id/repository/:action', :conditions => {:method => :post}
Chris@0 224 end
Chris@0 225
Chris@0 226 map.connect 'attachments/:id', :controller => 'attachments', :action => 'show', :id => /\d+/
Chris@0 227 map.connect 'attachments/:id/:filename', :controller => 'attachments', :action => 'show', :id => /\d+/, :filename => /.*/
Chris@0 228 map.connect 'attachments/download/:id/:filename', :controller => 'attachments', :action => 'download', :id => /\d+/, :filename => /.*/
Chris@0 229
Chris@0 230 map.resources :groups
Chris@0 231
Chris@0 232 #left old routes at the bottom for backwards compat
Chris@441 233 map.connect 'projects/:project_id/queries/:action', :controller => 'queries'
Chris@0 234 map.connect 'projects/:project_id/issues/:action', :controller => 'issues'
chris@493 235 map.connect 'projects/:project_id/members/:action', :controller => 'members'
Chris@0 236 map.connect 'projects/:project_id/documents/:action', :controller => 'documents'
Chris@0 237 map.connect 'projects/:project_id/boards/:action/:id', :controller => 'boards'
Chris@0 238 map.connect 'boards/:board_id/topics/:action/:id', :controller => 'messages'
Chris@0 239 map.connect 'wiki/:id/:page/:action', :page => nil, :controller => 'wiki'
Chris@0 240 map.connect 'issues/:issue_id/relations/:action/:id', :controller => 'issue_relations'
Chris@0 241 map.connect 'projects/:project_id/news/:action', :controller => 'news'
Chris@0 242 map.connect 'projects/:project_id/timelog/:action/:id', :controller => 'timelog', :project_id => /.+/
Chris@0 243 map.with_options :controller => 'repositories' do |omap|
Chris@0 244 omap.repositories_show 'repositories/browse/:id/*path', :action => 'browse'
Chris@0 245 omap.repositories_changes 'repositories/changes/:id/*path', :action => 'changes'
Chris@0 246 omap.repositories_diff 'repositories/diff/:id/*path', :action => 'diff'
Chris@0 247 omap.repositories_entry 'repositories/entry/:id/*path', :action => 'entry'
Chris@0 248 omap.repositories_entry 'repositories/annotate/:id/*path', :action => 'annotate'
Chris@0 249 omap.connect 'repositories/revision/:id/:rev', :action => 'revision'
Chris@0 250 end
Chris@0 251
Chris@0 252 map.with_options :controller => 'sys' do |sys|
Chris@0 253 sys.connect 'sys/projects.:format', :action => 'projects', :conditions => {:method => :get}
Chris@0 254 sys.connect 'sys/projects/:id/repository.:format', :action => 'create_project_repository', :conditions => {:method => :post}
chris@437 255 sys.connect 'sys/projects/:id/external_repository.:format', :action => 'get_external_repo_url', :conditions => {:method => :get}
chris@218 256 sys.connect 'sys/projects/:id/embedded.:format', :action => 'set_embedded_active', :conditions => { :method => :post }
chris@437 257 sys.connect 'sys/projects/:id/repository_cache.:format', :action => 'clear_repository_cache', :conditions => {:method => :post}
Chris@0 258 end
Chris@0 259
Chris@0 260 # Install the default route as the lowest priority.
Chris@0 261 map.connect ':controller/:action/:id'
Chris@0 262 map.connect 'robots.txt', :controller => 'welcome', :action => 'robots'
Chris@0 263 # Used for OpenID
Chris@0 264 map.root :controller => 'account', :action => 'login'
Chris@0 265 end