summaryrefslogtreecommitdiffstats
path: root/config/routes.rb
diff options
context:
space:
mode:
authorEric Davis <edavis@littlestreamsoftware.com>2009-01-26 01:47:51 +0000
committerEric Davis <edavis@littlestreamsoftware.com>2009-01-26 01:47:51 +0000
commit765f7abc60334b278c97678c41f1ba458db283d0 (patch)
treeb038f8fc57b5fe2cb49e0bc8b5e6b68300cc97e6 /config/routes.rb
parentbcc9007196828635abf4ce0e0260766241e7b9d5 (diff)
downloadredmine-765f7abc60334b278c97678c41f1ba458db283d0.tar.gz
redmine-765f7abc60334b278c97678c41f1ba458db283d0.zip
Converted routing and urls to follow the Rails REST convention.
Patch supplied by commits from Gerrit Kaiser on Github. Existing routes will still work (backwards compatible) but any new urls will be generated using the new routing rules. Changes listed below: * made the URLs for some project tabs and project settings follow the new rails RESTful conventions of /collection/:id/subcollection/:sub_id * prettier URL for project roadmap * more nice project URLs * use GET for filtering form * prettified URLs used on issues tab * custom route for activity atom feeds * prettier repository urls * fixed broken route definition * fixed failing tests for issuecontroller that were hardcoding the url string * more RESTful routes for boards and messages * RESTful routes for wiki pages * RESTful routes for documents * moved old routes that are retained for compatibility to the bottom and grouped them together * added RESTful URIs for issues * RESTfulness for the news section * fixed route order * changed hardcoded URLs in tests * fixed badly written tests * fixed forgotten parameter in routes * changed hardcoded URLS to new scheme * changed project add url to the standard POST to collection * create new issue by POSTing to collection * changed hardcoded URLs in integrations tests * made project add form work again * restful routes for project deletion * prettier routes for project (un)archival * made routes table more readable * fixed note quoting * user routing * fixed bug * always sort by GET * Fixed: cross-project issue list should not show issues of projects for which the issue tracking module was disabled. * prettified URLs used on issues tab * urls for time log * fixed reply routing * eliminate revision query paremeter for diff and entry actions * fixed test failures with hard-coded urls * ensure ajax links always use get * refactored ajax link generation into separate method #1901 git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@2317 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'config/routes.rb')
-rw-r--r--config/routes.rb226
1 files changed, 214 insertions, 12 deletions
diff --git a/config/routes.rb b/config/routes.rb
index 0a4d3fd9f..ca66f4b57 100644
--- a/config/routes.rb
+++ b/config/routes.rb
@@ -12,39 +12,241 @@ ActionController::Routing::Routes.draw do |map|
end
map.home '', :controller => 'welcome'
+
map.signin 'login', :controller => 'account', :action => 'login'
map.signout 'logout', :controller => 'account', :action => 'logout'
- map.connect 'wiki/:id/:page/:action', :controller => 'wiki', :page => nil
map.connect 'roles/workflow/:id/:role_id/:tracker_id', :controller => 'roles', :action => 'workflow'
map.connect 'help/:ctrl/:page', :controller => 'help'
- #map.connect ':controller/:action/:id/:sort_key/:sort_order'
- map.connect 'issues/:issue_id/relations/:action/:id', :controller => 'issue_relations'
+ map.connect 'time_entries/:id/edit', :action => 'edit', :controller => 'timelog'
+ map.connect 'projects/:project_id/time_entries/new', :action => 'edit', :controller => 'timelog'
+ map.connect 'projects/:project_id/issues/:issue_id/time_entries/new', :action => 'edit', :controller => 'timelog'
+
+ map.with_options :controller => 'timelog' do |timelog|
+ timelog.connect 'projects/:project_id/time_entries', :action => 'details'
+
+ timelog.with_options :action => 'details', :conditions => {:method => :get} do |time_details|
+ time_details.connect 'time_entries'
+ time_details.connect 'time_entries.:format'
+ time_details.connect 'issues/:issue_id/time_entries'
+ time_details.connect 'issues/:issue_id/time_entries.:format'
+ time_details.connect 'projects/:project_id/time_entries.:format'
+ time_details.connect 'projects/:project_id/issues/:issue_id/time_entries'
+ time_details.connect 'projects/:project_id/issues/:issue_id/time_entries.:format'
+ end
+ timelog.connect 'projects/:project_id/time_entries/report', :action => 'report'
+ timelog.with_options :action => 'report',:conditions => {:method => :get} do |time_report|
+ time_report.connect 'time_entries/report'
+ time_report.connect 'time_entries/report.:format'
+ time_report.connect 'projects/:project_id/time_entries/report.:format'
+ end
+
+ timelog.with_options :action => 'edit', :conditions => {:method => :get} do |time_edit|
+ time_edit.connect 'issues/:issue_id/time_entries/new'
+ end
+
+ timelog.connect 'time_entries/:id/destroy', :action => 'destroy', :conditions => {:method => :post}
+ end
+
+ map.connect 'projects/:id/wiki', :controller => 'wikis', :action => 'edit', :conditions => {:method => :post}
+ map.connect 'projects/:id/wiki/destroy', :controller => 'wikis', :action => 'destroy', :conditions => {:method => :get}
+ map.connect 'projects/:id/wiki/destroy', :controller => 'wikis', :action => 'destroy', :conditions => {:method => :post}
+ map.with_options :controller => 'wiki' do |wiki_routes|
+ wiki_routes.with_options :conditions => {:method => :get} do |wiki_views|
+ wiki_views.connect 'projects/:id/wiki/:page', :action => 'special', :page => /page_index|date_index|export/i
+ wiki_views.connect 'projects/:id/wiki/:page', :action => 'index', :page => nil
+ wiki_views.connect 'projects/:id/wiki/:page/edit', :action => 'edit'
+ wiki_views.connect 'projects/:id/wiki/:page/rename', :action => 'rename'
+ wiki_views.connect 'projects/:id/wiki/:page/history', :action => 'history'
+ wiki_views.connect 'projects/:id/wiki/:page/diff/:version/vs/:version_from', :action => 'diff'
+ wiki_views.connect 'projects/:id/wiki/:page/annotate/:version', :action => 'annotate'
+ end
+
+ wiki_routes.connect 'projects/:id/wiki/:page/:action',
+ :action => /edit|rename|destroy|preview|protect/,
+ :conditions => {:method => :post}
+ end
+
+ map.with_options :controller => 'messages' do |messages_routes|
+ messages_routes.with_options :conditions => {:method => :get} do |messages_views|
+ messages_views.connect 'boards/:board_id/topics/new', :action => 'new'
+ messages_views.connect 'boards/:board_id/topics/:id', :action => 'show'
+ messages_views.connect 'boards/:board_id/topics/:id/edit', :action => 'edit'
+ end
+ messages_routes.with_options :conditions => {:method => :post} do |messages_actions|
+ messages_actions.connect 'boards/:board_id/topics/new', :action => 'new'
+ messages_actions.connect 'boards/:board_id/topics/:id/replies', :action => 'reply'
+ messages_actions.connect 'boards/:board_id/topics/:id/:action', :action => /edit|destroy/
+ end
+ end
+
+ map.with_options :controller => 'boards' do |board_routes|
+ board_routes.with_options :conditions => {:method => :get} do |board_views|
+ board_views.connect 'projects/:project_id/boards', :action => 'index'
+ board_views.connect 'projects/:project_id/boards/new', :action => 'new'
+ board_views.connect 'projects/:project_id/boards/:id', :action => 'show'
+ board_views.connect 'projects/:project_id/boards/:id/edit', :action => 'edit'
+ end
+ board_routes.with_options :conditions => {:method => :post} do |board_actions|
+ board_actions.connect 'projects/:project_id/boards', :action => 'new'
+ board_actions.connect 'projects/:project_id/boards/:id/:action', :action => /edit|destroy/
+ end
+ end
+
+ map.with_options :controller => 'documents' do |document_routes|
+ document_routes.with_options :conditions => {:method => :get} do |document_views|
+ document_views.connect 'projects/:project_id/documents', :action => 'index'
+ document_views.connect 'projects/:project_id/documents/new', :action => 'new'
+ document_views.connect 'documents/:id', :action => 'show'
+ document_views.connect 'documents/:id/edit', :action => 'edit'
+ end
+ document_routes.with_options :conditions => {:method => :post} do |document_actions|
+ document_actions.connect 'projects/:project_id/documents', :action => 'new'
+ document_actions.connect 'documents/:id/:action', :action => /destroy|edit/
+ end
+ end
+
+ map.with_options :controller => 'issues' do |issues_routes|
+ issues_routes.with_options :conditions => {:method => :get} do |issues_views|
+ issues_views.connect 'issues', :action => 'index'
+ issues_views.connect 'issues.:format', :action => 'index'
+ issues_views.connect 'projects/:project_id/issues.:format', :action => 'index'
+ issues_views.connect 'projects/:project_id/issues/new', :action => 'new'
+ issues_views.connect 'projects/:project_id/issues/:copy_from/copy', :action => 'new'
+ issues_views.connect 'issues/:id', :action => 'show'
+ issues_views.connect 'issues/:id.:format', :action => 'show'
+ issues_views.connect 'issues/:id/edit', :action => 'edit'
+ issues_views.connect 'issues/:id/move', :action => 'move'
+ end
+ issues_routes.with_options :conditions => {:method => :post} do |issues_actions|
+ issues_actions.connect 'projects/:project_id/issues', :action => 'new'
+ issues_actions.connect 'issues/:id/quoted', :action => 'reply'
+ issues_actions.connect 'issues/:id/:action',
+ :action => /edit|move|destroy/
+ end
+ end
+
+ map.with_options :controller => 'issue_relations', :conditions => {:method => :post} do |relations|
+ relations.connect 'issues/:issue_id/relations/:id', :action => 'new'
+ relations.connect 'issues/:issue_id/relations/:id/destroy', :action => 'destroy'
+ end
+
+ map.with_options :controller => 'reports', :action => 'issue_report', :conditions => {:method => :get} do |reports|
+ reports.connect 'projects/:id/issues/report'
+ reports.connect 'projects/:id/issues/report/:detail'
+ end
+
+ map.with_options :controller => 'news' do |news_routes|
+ news_routes.with_options :conditions => {:method => :get} do |news_views|
+ news_views.connect 'news', :action => 'index'
+ news_views.connect 'projects/:project_id/news', :action => 'index'
+ news_views.connect 'projects/:project_id/news.:format', :action => 'index'
+ news_views.connect 'news.:format', :action => 'index'
+ news_views.connect 'projects/:project_id/news/new', :action => 'new'
+ news_views.connect 'news/:id', :action => 'show'
+ news_views.connect 'news/:id/edit', :action => 'edit'
+ end
+ news_routes.with_options do |news_actions|
+ news_actions.connect 'projects/:project_id/news', :action => 'new'
+ news_actions.connect 'news/:id/edit', :action => 'edit'
+ news_actions.connect 'news/:id/destroy', :action => 'destroy'
+ end
+ end
+
+ map.connect 'projects/:id/members/new', :controller => 'members', :action => 'new'
+
+ map.with_options :controller => 'users' do |users|
+ users.with_options :conditions => {:method => :get} do |user_views|
+ user_views.connect 'users', :action => 'list'
+ user_views.connect 'users', :action => 'index'
+ user_views.connect 'users/new', :action => 'add'
+ user_views.connect 'users/:id/edit/:tab', :action => 'edit', :tab => nil
+ end
+ users.with_options :conditions => {:method => :post} do |user_actions|
+ user_actions.connect 'users', :action => 'add'
+ user_actions.connect 'users/new', :action => 'add'
+ user_actions.connect 'users/:id/edit', :action => 'edit'
+ user_actions.connect 'users/:id/memberships', :action => 'edit_membership'
+ user_actions.connect 'users/:id/memberships/:membership_id', :action => 'edit_membership'
+ user_actions.connect 'users/:id/memberships/:membership_id/destroy', :action => 'destroy_membership'
+ end
+ end
+
+ map.with_options :controller => 'projects' do |projects|
+ projects.with_options :conditions => {:method => :get} do |project_views|
+ project_views.connect 'projects', :action => 'index'
+ project_views.connect 'projects.:format', :action => 'index'
+ project_views.connect 'projects/new', :action => 'add'
+ project_views.connect 'projects/:id', :action => 'show'
+ project_views.connect 'projects/:id/:action', :action => /roadmap|changelog|destroy|settings/
+ project_views.connect 'projects/:id/files', :action => 'list_files'
+ project_views.connect 'projects/:id/files/new', :action => 'add_file'
+ project_views.connect 'projects/:id/versions/new', :action => 'add_version'
+ project_views.connect 'projects/:id/categories/new', :action => 'add_issue_category'
+ project_views.connect 'projects/:id/settings/:tab', :action => 'settings'
+ end
+
+ projects.with_options :action => 'activity', :conditions => {:method => :get} do |activity|
+ activity.connect 'projects/:id/activity'
+ activity.connect 'projects/:id/activity.:format'
+ activity.connect 'activity'
+ activity.connect 'activity.:format'
+ end
+
+ projects.with_options :conditions => {:method => :post} do |project_actions|
+ project_actions.connect 'projects/new', :action => 'add'
+ project_actions.connect 'projects', :action => 'add'
+ project_actions.connect 'projects/:id/:action', :action => /destroy|archive|unarchive/
+ project_actions.connect 'projects/:id/files/new', :action => 'add_file'
+ project_actions.connect 'projects/:id/versions/new', :action => 'add_version'
+ project_actions.connect 'projects/:id/categories/new', :action => 'add_issue_category'
+ end
+ end
+
+ map.with_options :controller => 'repositories' do |repositories|
+ repositories.with_options :conditions => {:method => :get} do |repository_views|
+ repositories.connect 'projects/:id/repository', :action => 'show'
+ repositories.connect 'projects/:id/repository/edit', :action => 'edit'
+ repositories.connect 'projects/:id/repository/statistics', :action => 'stats'
+ repositories.connect 'projects/:id/repository/revisions', :action => 'revisions'
+ repositories.connect 'projects/:id/repository/revisions.:format', :action => 'revisions'
+ repositories.connect 'projects/:id/repository/revisions/:rev', :action => 'revision'
+ repositories.connect 'projects/:id/repository/revisions/:rev/diff', :action => 'diff'
+ repositories.connect 'projects/:id/repository/revisions/:rev/diff.:format', :action => 'diff'
+ repositories.connect 'projects/:id/repository/revisions/:rev/:action/*path'
+ repositories.connect 'projects/:id/repository/:action/*path'
+ end
+
+ repositories.connect 'projects/:id/repository/edit', :action => 'edit', :conditions => {:method => :post}
+ end
+
+ map.connect 'attachments/:id', :controller => 'attachments', :action => 'show', :id => /\d+/
+ map.connect 'attachments/:id/:filename', :controller => 'attachments', :action => 'show', :id => /\d+/, :filename => /.*/
+ map.connect 'attachments/download/:id/:filename', :controller => 'attachments', :action => 'download', :id => /\d+/, :filename => /.*/
+
+
+ #left old routes at the bottom for backwards compat
map.connect 'projects/:project_id/issues/:action', :controller => 'issues'
- map.connect 'projects/:project_id/news/:action', :controller => 'news'
map.connect 'projects/:project_id/documents/:action', :controller => 'documents'
map.connect 'projects/:project_id/boards/:action/:id', :controller => 'boards'
- map.connect 'projects/:project_id/timelog/:action/:id', :controller => 'timelog', :project_id => /.+/
map.connect 'boards/:board_id/topics/:action/:id', :controller => 'messages'
-
+ map.connect 'wiki/:id/:page/:action', :page => nil, :controller => 'wiki'
+ map.connect 'issues/:issue_id/relations/:action/:id', :controller => 'issue_relations'
+ map.connect 'projects/:project_id/news/:action', :controller => 'news'
+ map.connect 'projects/:project_id/timelog/:action/:id', :controller => 'timelog', :project_id => /.+/
map.with_options :controller => 'repositories' do |omap|
omap.repositories_show 'repositories/browse/:id/*path', :action => 'browse'
omap.repositories_changes 'repositories/changes/:id/*path', :action => 'changes'
omap.repositories_diff 'repositories/diff/:id/*path', :action => 'diff'
omap.repositories_entry 'repositories/entry/:id/*path', :action => 'entry'
omap.repositories_entry 'repositories/annotate/:id/*path', :action => 'annotate'
- omap.repositories_revision 'repositories/revision/:id/:rev', :action => 'revision'
+ omap.connect 'repositories/revision/:id/:rev', :action => 'revision'
end
-
- map.connect 'attachments/:id', :controller => 'attachments', :action => 'show', :id => /\d+/
- map.connect 'attachments/:id/:filename', :controller => 'attachments', :action => 'show', :id => /\d+/, :filename => /.*/
- map.connect 'attachments/download/:id/:filename', :controller => 'attachments', :action => 'download', :id => /\d+/, :filename => /.*/
# Allow downloading Web Service WSDL as a file with an extension
# instead of a file named 'wsdl'
map.connect ':controller/service.wsdl', :action => 'wsdl'
-
# Install the default route as the lowest priority.
map.connect ':controller/:action/:id'