diff options
Diffstat (limited to 'config/routes.rb')
-rw-r--r-- | config/routes.rb | 670 |
1 files changed, 296 insertions, 374 deletions
diff --git a/config/routes.rb b/config/routes.rb index de2a7c8ee..d2f1cc22c 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -1,398 +1,320 @@ -ActionController::Routing::Routes.draw do |map| - # Add your own custom routes here. - # The priority is based upon order of creation: first created -> highest priority. - - # Here's a sample route: - # map.connect 'products/:id', :controller => 'catalog', :action => 'view' - # Keep in mind you can assign values other than :controller and :action - - map.home '', :controller => 'welcome', :conditions => {:method => :get} - - map.signin 'login', :controller => 'account', :action => 'login', - :conditions => {:method => [:get, :post]} - map.signout 'logout', :controller => 'account', :action => 'logout', - :conditions => {:method => :get} - map.connect 'account/register', :controller => 'account', :action => 'register', - :conditions => {:method => [:get, :post]} - map.connect 'account/lost_password', :controller => 'account', :action => 'lost_password', - :conditions => {:method => [:get, :post]} - map.connect 'account/activate', :controller => 'account', :action => 'activate', - :conditions => {:method => :get} - - 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, :post]} - - 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' +# Redmine - project management software +# Copyright (C) 2006-2012 Jean-Philippe Lang +# +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License +# as published by the Free Software Foundation; either version 2 +# of the License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + +RedmineApp::Application.routes.draw do + root :to => 'welcome#index', :as => 'home' + + match 'login', :to => 'account#login', :as => 'signin' + match 'logout', :to => 'account#logout', :as => 'signout' + match 'account/register', :to => 'account#register', :via => [:get, :post] + match 'account/lost_password', :to => 'account#lost_password', :via => [:get, :post] + match 'account/activate', :to => 'account#activate', :via => :get + + match '/news/preview', :controller => 'previews', :action => 'news', :as => 'preview_news' + match '/issues/preview/new/:project_id', :to => 'previews#issue', :as => 'preview_new_issue' + match '/issues/preview/edit/:id', :to => 'previews#issue', :as => 'preview_edit_issue' + match '/issues/preview', :to => 'previews#issue', :as => 'preview_issue' + + match 'projects/:id/wiki', :to => 'wikis#edit', :via => :post + match 'projects/:id/wiki/destroy', :to => 'wikis#destroy', :via => [:get, :post] + + match 'boards/:board_id/topics/new', :to => 'messages#new', :via => [:get, :post] + get 'boards/:board_id/topics/:id', :to => 'messages#show' + match 'boards/:board_id/topics/quote/:id', :to => 'messages#quote', :via => [:get, :post] + get 'boards/:board_id/topics/:id/edit', :to => 'messages#edit' + + post 'boards/:board_id/topics/preview', :to => 'messages#preview' + post 'boards/:board_id/topics/:id/replies', :to => 'messages#reply' + post 'boards/:board_id/topics/:id/edit', :to => 'messages#edit' + post 'boards/:board_id/topics/:id/destroy', :to => 'messages#destroy' + + # Misc issue routes. TODO: move into resources + match '/issues/auto_complete', :to => 'auto_completes#issues', :via => :get, :as => 'auto_complete_issues' + match '/issues/context_menu', :to => 'context_menus#issues', :as => 'issues_context_menu' + match '/issues/changes', :to => 'journals#index', :as => 'issue_changes' + match '/issues/:id/quoted', :to => 'journals#new', :id => /\d+/, :via => :post, :as => 'quoted_issue' + + match '/journals/diff/:id', :to => 'journals#diff', :id => /\d+/, :via => :get + match '/journals/edit/:id', :to => 'journals#edit', :id => /\d+/, :via => [:get, :post] + + match '/projects/:project_id/issues/gantt', :to => 'gantts#show' + match '/issues/gantt', :to => 'gantts#show' + + match '/projects/:project_id/issues/calendar', :to => 'calendars#show' + match '/issues/calendar', :to => 'calendars#show' + + match 'projects/:id/issues/report', :to => 'reports#issue_report', :via => :get + match 'projects/:id/issues/report/:detail', :to => 'reports#issue_report_details', :via => :get + + match 'my/account', :controller => 'my', :action => 'account', :via => [:get, :post] + match 'my/account/destroy', :controller => 'my', :action => 'destroy', :via => [:get, :post] + match 'my/page', :controller => 'my', :action => 'page', :via => :get + match 'my', :controller => 'my', :action => 'index', :via => :get # Redirects to my/page + match 'my/reset_rss_key', :controller => 'my', :action => 'reset_rss_key', :via => :post + match 'my/reset_api_key', :controller => 'my', :action => 'reset_api_key', :via => :post + match 'my/password', :controller => 'my', :action => 'password', :via => [:get, :post] + match 'my/page_layout', :controller => 'my', :action => 'page_layout', :via => :get + match 'my/add_block', :controller => 'my', :action => 'add_block', :via => :post + match 'my/remove_block', :controller => 'my', :action => 'remove_block', :via => :post + match 'my/order_blocks', :controller => 'my', :action => 'order_blocks', :via => :post + + resources :users + match 'users/:id/memberships/:membership_id', :to => 'users#edit_membership', :via => :put, :as => 'user_membership' + match 'users/:id/memberships/:membership_id', :to => 'users#destroy_membership', :via => :delete + match 'users/:id/memberships', :to => 'users#edit_membership', :via => :post, :as => 'user_memberships' + + match 'watchers/new', :controller=> 'watchers', :action => 'new', :via => :get + match 'watchers', :controller=> 'watchers', :action => 'create', :via => :post + match 'watchers/append', :controller=> 'watchers', :action => 'append', :via => :post + match 'watchers/destroy', :controller=> 'watchers', :action => 'destroy', :via => :post + match 'watchers/watch', :controller=> 'watchers', :action => 'watch', :via => :post + match 'watchers/unwatch', :controller=> 'watchers', :action => 'unwatch', :via => :post + match 'watchers/autocomplete_for_user', :controller=> 'watchers', :action => 'autocomplete_for_user', :via => :get + + match 'projects/:id/settings/:tab', :to => "projects#settings" + + resources :projects do + member do + get 'settings' + post 'modules' + post 'archive' + post 'unarchive' + match 'copy', :via => [:get, :post] 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/preview', :action => 'preview' - messages_actions.connect 'boards/:board_id/topics/quote/:id', :action => 'quote' - messages_actions.connect 'boards/:board_id/topics/:id/replies', :action => 'reply' - messages_actions.connect 'boards/:board_id/topics/:id/edit', :action => 'edit' - messages_actions.connect 'boards/:board_id/topics/:id/destroy', :action => 'destroy' + + resources :memberships, :shallow => true, :controller => 'members', :only => [:index, :show, :create, :update, :destroy] do + collection do + get 'autocomplete' + end end - end - # Misc issue routes. TODO: move into resources - map.auto_complete_issues '/issues/auto_complete', :controller => 'auto_completes', - :action => 'issues', :conditions => { :method => :get } - # TODO: would look nicer as /issues/:id/preview - map.preview_new_issue '/issues/preview/new/:project_id', :controller => 'previews', - :action => 'issue' - map.preview_edit_issue '/issues/preview/edit/:id', :controller => 'previews', - :action => 'issue' - map.issues_context_menu '/issues/context_menu', - :controller => 'context_menus', :action => 'issues' - - map.issue_changes '/issues/changes', :controller => 'journals', :action => 'index' - map.quoted_issue '/issues/:id/quoted', :controller => 'journals', :action => 'new', - :id => /\d+/, :conditions => { :method => :post } - - map.connect '/journals/diff/:id', :controller => 'journals', :action => 'diff', - :id => /\d+/, :conditions => { :method => :get } - map.connect '/journals/edit/:id', :controller => 'journals', :action => 'edit', - :id => /\d+/, :conditions => { :method => [:get, :post] } - - map.with_options :controller => 'gantts', :action => 'show' do |gantts_routes| - gantts_routes.connect '/projects/:project_id/issues/gantt' - gantts_routes.connect '/projects/:project_id/issues/gantt.:format' - gantts_routes.connect '/issues/gantt.:format' - end + resource :enumerations, :controller => 'project_enumerations', :only => [:update, :destroy] - map.with_options :controller => 'calendars', :action => 'show' do |calendars_routes| - calendars_routes.connect '/projects/:project_id/issues/calendar' - calendars_routes.connect '/issues/calendar' - end + match 'issues/:copy_from/copy', :to => 'issues#new' + resources :issues, :only => [:index, :new, :create] do + resources :time_entries, :controller => 'timelog' do + collection do + get 'report' + end + end + end + # issue form update + match 'issues/new', :controller => 'issues', :action => 'new', :via => [:put, :post], :as => 'issue_form' - map.with_options :controller => 'reports', :conditions => {:method => :get} do |reports| - reports.connect 'projects/:id/issues/report', :action => 'issue_report' - reports.connect 'projects/:id/issues/report/:detail', :action => 'issue_report_details' - end + resources :files, :only => [:index, :new, :create] - map.connect 'my/account', :controller => 'my', :action => 'account', - :conditions => {:method => [:get, :post]} - map.connect 'my/account/destroy', :controller => 'my', :action => 'destroy', - :conditions => {:method => [:get, :post]} - map.connect 'my/page', :controller => 'my', :action => 'page', - :conditions => {:method => :get} - # Redirects to my/page - map.connect 'my', :controller => 'my', :action => 'index', - :conditions => {:method => :get} - map.connect 'my/reset_rss_key', :controller => 'my', :action => 'reset_rss_key', - :conditions => {:method => :post} - map.connect 'my/reset_api_key', :controller => 'my', :action => 'reset_api_key', - :conditions => {:method => :post} - map.connect 'my/password', :controller => 'my', :action => 'password', - :conditions => {:method => [:get, :post]} - map.connect 'my/page_layout', :controller => 'my', :action => 'page_layout', - :conditions => {:method => :get} - map.connect 'my/add_block', :controller => 'my', :action => 'add_block', - :conditions => {:method => :post} - map.connect 'my/remove_block', :controller => 'my', :action => 'remove_block', - :conditions => {:method => :post} - map.connect 'my/order_blocks', :controller => 'my', :action => 'order_blocks', - :conditions => {:method => :post} - - map.with_options :controller => 'users' do |users| - users.user_membership 'users/:id/memberships/:membership_id', - :action => 'edit_membership', - :conditions => {:method => :put} - users.connect 'users/:id/memberships/:membership_id', - :action => 'destroy_membership', - :conditions => {:method => :delete} - users.user_memberships 'users/:id/memberships', - :action => 'edit_membership', - :conditions => {:method => :post} - end - map.resources :users - - # For nice "roadmap" in the url for the index action - map.connect 'projects/:project_id/roadmap', :controller => 'versions', :action => 'index' - - map.preview_news '/news/preview', :controller => 'previews', :action => 'news' - map.connect 'news/:id/comments', :controller => 'comments', - :action => 'create', :conditions => {:method => :post} - map.connect 'news/:id/comments/:comment_id', :controller => 'comments', - :action => 'destroy', :conditions => {:method => :delete} - - map.connect 'watchers/new', :controller=> 'watchers', :action => 'new', - :conditions => {:method => :get} - map.connect 'watchers', :controller=> 'watchers', :action => 'create', - :conditions => {:method => :post} - map.connect 'watchers/append', :controller=> 'watchers', :action => 'append', - :conditions => {:method => :post} - map.connect 'watchers/destroy', :controller=> 'watchers', :action => 'destroy', - :conditions => {:method => :post} - map.connect 'watchers/watch', :controller=> 'watchers', :action => 'watch', - :conditions => {:method => :post} - map.connect 'watchers/unwatch', :controller=> 'watchers', :action => 'unwatch', - :conditions => {:method => :post} - map.connect 'watchers/autocomplete_for_user', :controller=> 'watchers', :action => 'autocomplete_for_user', - :conditions => {:method => :get} + resources :versions, :except => [:index, :show, :edit, :update, :destroy] do + collection do + put 'close_completed' + end + end + match 'versions.:format', :to => 'versions#index' + match 'roadmap', :to => 'versions#index', :format => false + match 'versions', :to => 'versions#index' - # TODO: port to be part of the resources route(s) - map.with_options :conditions => {:method => :get} do |project_views| - project_views.connect 'projects/:id/settings/:tab', - :controller => 'projects', :action => 'settings' - project_views.connect 'projects/:project_id/issues/:copy_from/copy', - :controller => 'issues', :action => 'new' - end + resources :news, :except => [:show, :edit, :update, :destroy] + resources :time_entries, :controller => 'timelog' do + get 'report', :on => :collection + end + resources :queries, :only => [:new, :create] + resources :issue_categories, :shallow => true + resources :documents, :except => [:show, :edit, :update, :destroy] + resources :boards + resources :repositories, :shallow => true, :except => [:index, :show] do + member do + match 'committers', :via => [:get, :post] + end + end - map.resources :projects, :member => { - :copy => [:get, :post], - :settings => :get, - :modules => :post, - :archive => :post, - :unarchive => :post - } do |project| - project.resource :enumerations, :controller => 'project_enumerations', - :only => [:update, :destroy] - # issue form update - project.issue_form 'issues/new', :controller => 'issues', - :action => 'new', :conditions => {:method => [:post, :put]} - project.resources :issues, :only => [:index, :new, :create] do |issues| - issues.resources :time_entries, :controller => 'timelog', - :collection => {:report => :get} + match 'wiki/index', :controller => 'wiki', :action => 'index', :via => :get + match 'wiki/:id/diff/:version/vs/:version_from', :controller => 'wiki', :action => 'diff' + match 'wiki/:id/diff/:version', :controller => 'wiki', :action => 'diff' + resources :wiki, :except => [:index, :new, :create] do + member do + get 'rename' + post 'rename' + get 'history' + get 'diff' + match 'preview', :via => [:post, :put] + post 'protect' + post 'add_attachment' + end + collection do + get 'export' + get 'date_index' + end end + match 'wiki', :controller => 'wiki', :action => 'show', :via => :get + match 'wiki/:id/annotate/:version', :controller => 'wiki', :action => 'annotate' + end - project.resources :files, :only => [:index, :new, :create] - project.resources :versions, :shallow => true, - :collection => {:close_completed => :put}, - :member => {:status_by => :post} - project.resources :news, :shallow => true - project.resources :time_entries, :controller => 'timelog', - :collection => {:report => :get} - project.resources :queries, :only => [:new, :create] - project.resources :issue_categories, :shallow => true - project.resources :documents, :shallow => true, :member => {:add_attachment => :post} - project.resources :boards - project.resources :repositories, :shallow => true, :except => [:index, :show], - :member => {:committers => [:get, :post]} - project.resources :memberships, :shallow => true, :controller => 'members', - :only => [:index, :show, :create, :update, :destroy], - :collection => {:autocomplete => :get} - - project.wiki_start_page 'wiki', :controller => 'wiki', :action => 'show', :conditions => {:method => :get} - project.wiki_index 'wiki/index', :controller => 'wiki', :action => 'index', :conditions => {:method => :get} - project.wiki_diff 'wiki/:id/diff/:version', :controller => 'wiki', :action => 'diff', :version => nil - project.wiki_diff 'wiki/:id/diff/:version/vs/:version_from', :controller => 'wiki', :action => 'diff' - project.wiki_annotate 'wiki/:id/annotate/:version', :controller => 'wiki', :action => 'annotate' - project.resources :wiki, :except => [:new, :create], :member => { - :rename => [:get, :post], - :history => :get, - :preview => :any, - :protect => :post, - :add_attachment => :post - }, :collection => { - :export => :get, - :date_index => :get - } + resources :issues do + collection do + match 'bulk_edit', :via => [:get, :post] + post 'bulk_update' + end + resources :time_entries, :controller => 'timelog' do + collection do + get 'report' + end + end + resources :relations, :shallow => true, :controller => 'issue_relations', :only => [:index, :show, :create, :destroy] end + match '/issues', :controller => 'issues', :action => 'destroy', :via => :delete + + resources :queries, :except => [:show] - map.connect 'news', :controller => 'news', :action => 'index' - map.connect 'news.:format', :controller => 'news', :action => 'index' - - map.resources :queries, :except => [:show] - map.resources :issues, - :collection => {:bulk_edit => [:get, :post], :bulk_update => :post} do |issues| - issues.resources :time_entries, :controller => 'timelog', - :collection => {:report => :get} - issues.resources :relations, :shallow => true, - :controller => 'issue_relations', - :only => [:index, :show, :create, :destroy] + resources :news, :only => [:index, :show, :edit, :update, :destroy] + match '/news/:id/comments', :to => 'comments#create', :via => :post + match '/news/:id/comments/:comment_id', :to => 'comments#destroy', :via => :delete + + resources :versions, :only => [:show, :edit, :update, :destroy] do + post 'status_by', :on => :member end - # Bulk deletion - map.connect '/issues', :controller => 'issues', :action => 'destroy', - :conditions => {:method => :delete} - - map.connect '/time_entries/destroy', - :controller => 'timelog', :action => 'destroy', - :conditions => { :method => :delete } - map.time_entries_context_menu '/time_entries/context_menu', - :controller => 'context_menus', :action => 'time_entries' - - map.resources :time_entries, :controller => 'timelog', - :collection => {:report => :get, :bulk_edit => :get, :bulk_update => :post} - - map.with_options :controller => 'activities', :action => 'index', - :conditions => {:method => :get} do |activity| - activity.connect 'projects/:id/activity' - activity.connect 'projects/:id/activity.:format' - activity.connect 'activity', :id => nil - activity.connect 'activity.:format', :id => nil + + resources :documents, :only => [:show, :edit, :update, :destroy] do + post 'add_attachment', :on => :member end - map.with_options :controller => 'repositories' do |repositories| - repositories.with_options :conditions => {:method => :get} do |repository_views| - repository_views.connect 'projects/:id/repository', - :action => 'show' - - repository_views.connect 'projects/:id/repository/:repository_id/statistics', - :action => 'stats' - repository_views.connect 'projects/:id/repository/:repository_id/graph', - :action => 'graph' - - repository_views.connect 'projects/:id/repository/statistics', - :action => 'stats' - repository_views.connect 'projects/:id/repository/graph', - :action => 'graph' - - repository_views.connect 'projects/:id/repository/:repository_id/revisions', - :action => 'revisions' - repository_views.connect 'projects/:id/repository/:repository_id/revisions.:format', - :action => 'revisions' - repository_views.connect 'projects/:id/repository/:repository_id/revisions/:rev', - :action => 'revision' - repository_views.connect 'projects/:id/repository/:repository_id/revisions/:rev/issues', - :action => 'add_related_issue', :conditions => {:method => :post} - repository_views.connect 'projects/:id/repository/:repository_id/revisions/:rev/issues/:issue_id', - :action => 'remove_related_issue', :conditions => {:method => :delete} - repository_views.connect 'projects/:id/repository/:repository_id/revisions/:rev/diff', - :action => 'diff' - repository_views.connect 'projects/:id/repository/:repository_id/revisions/:rev/diff.:format', - :action => 'diff' - repository_views.connect 'projects/:id/repository/:repository_id/revisions/:rev/raw/*path', - :action => 'entry', :format => 'raw' - repository_views.connect 'projects/:id/repository/:repository_id/revisions/:rev/:action/*path', - :requirements => { - :action => /(browse|show|entry|changes|annotate|diff)/, - :rev => /[a-z0-9\.\-_]+/ - } - repository_views.connect 'projects/:id/repository/:repository_id/raw/*path', - :action => 'entry', :format => 'raw' - repository_views.connect 'projects/:id/repository/:repository_id/:action/*path', - :requirements => { :action => /(browse|entry|changes|annotate|diff)/ } - repository_views.connect 'projects/:id/repository/:repository_id/show/*path', - :requirements => { :path => /.+/ } - - repository_views.connect 'projects/:id/repository/:repository_id/revision', - :action => 'revision' - - repository_views.connect 'projects/:id/repository/revisions', - :action => 'revisions' - repository_views.connect 'projects/:id/repository/revisions.:format', - :action => 'revisions' - repository_views.connect 'projects/:id/repository/revisions/:rev', - :action => 'revision' - repository_views.connect 'projects/:id/repository/revisions/:rev/issues', - :action => 'add_related_issue', :conditions => {:method => :post} - repository_views.connect 'projects/:id/repository/revisions/:rev/issues/:issue_id', - :action => 'remove_related_issue', :conditions => {:method => :delete} - repository_views.connect 'projects/:id/repository/revisions/:rev/diff', - :action => 'diff' - repository_views.connect 'projects/:id/repository/revisions/:rev/diff.:format', - :action => 'diff' - repository_views.connect 'projects/:id/repository/revisions/:rev/raw/*path', - :action => 'entry', :format => 'raw' - repository_views.connect 'projects/:id/repository/revisions/:rev/:action/*path', - :requirements => { - :action => /(browse|show|entry|changes|annotate|diff)/, - :rev => /[a-z0-9\.\-_]+/ - } - repository_views.connect 'projects/:id/repository/raw/*path', - :action => 'entry', :format => 'raw' - repository_views.connect 'projects/:id/repository/:action/*path', - :requirements => { :action => /(browse|show|entry|changes|annotate|diff)/ } - - repository_views.connect 'projects/:id/repository/revision', - :action => 'revision' - - repository_views.connect 'projects/:id/repository/:repository_id', - :action => 'show' + match '/time_entries/context_menu', :to => 'context_menus#time_entries', :as => :time_entries_context_menu + + resources :time_entries, :controller => 'timelog', :except => :destroy do + collection do + get 'report' + get 'bulk_edit' + post 'bulk_update' end end + match '/time_entries/:id', :to => 'timelog#destroy', :via => :delete, :id => /\d+/ + # TODO: delete /time_entries for bulk deletion + match '/time_entries/destroy', :to => 'timelog#destroy', :via => :delete + + # TODO: port to be part of the resources route(s) + match 'projects/:id/settings/:tab', :to => 'projects#settings', :via => :get + + get 'projects/:id/activity', :to => 'activities#index' + get 'projects/:id/activity.:format', :to => 'activities#index' + get 'activity', :to => 'activities#index' + + # repositories routes + get 'projects/:id/repository/:repository_id/statistics', :to => 'repositories#stats' + get 'projects/:id/repository/:repository_id/graph', :to => 'repositories#graph' + match 'projects/:id/repository/:repository_id/committers', :to => 'repositories#committers', :via => [:get, :post] + + get 'projects/:id/repository/:repository_id/revisions/:rev', :to => 'repositories#revision' + get 'projects/:id/repository/:repository_id/revision', :to => 'repositories#revision' + post 'projects/:id/repository/:repository_id/revisions/:rev/issues', :to => 'repositories#add_related_issue' + delete 'projects/:id/repository/:repository_id/revisions/:rev/issues/:issue_id', :to => 'repositories#remove_related_issue' + get 'projects/:id/repository/:repository_id/revisions', :to => 'repositories#revisions' + get 'projects/:id/repository/:repository_id/revisions/:rev/:format(/*path(.:ext))', :to => 'repositories#entry', :format => /raw/ + get 'projects/:id/repository/:repository_id/revisions/:rev/:action(/*path(.:ext))', :controller => 'repositories', :action => /(browse|show|entry|changes|annotate|diff)/ + + get 'projects/:id/repository/statistics', :to => 'repositories#stats' + get 'projects/:id/repository/graph', :to => 'repositories#graph' + match 'projects/:id/repository/committers', :to => 'repositories#committers', :via => [:get, :post] + + get 'projects/:id/repository/revisions', :to => 'repositories#revisions' + get 'projects/:id/repository/revisions/:rev', :to => 'repositories#revision' + get 'projects/:id/repository/revision', :to => 'repositories#revision' + post 'projects/:id/repository/revisions/:rev/issues', :to => 'repositories#add_related_issue' + delete 'projects/:id/repository/revisions/:rev/issues/:issue_id', :to => 'repositories#remove_related_issue' + get 'projects/:id/repository/revisions/:rev/:format(/*path(.:ext))', :to => 'repositories#entry', :format => /raw/ + get 'projects/:id/repository/revisions/:rev/:action(/*path(.:ext))', :controller => 'repositories', :action => /(browse|show|entry|changes|annotate|diff)/ + get 'projects/:id/repository/:repository_id/:format(/*path(.:ext))', :to => 'repositories#entry', :format => /raw/ + get 'projects/:id/repository/:repository_id/:action(/*path(.:ext))', :controller => 'repositories', :action => /(browse|show|entry|changes|annotate|diff)/ + get 'projects/:id/repository/:repository_id', :to => 'repositories#show', :path => nil + + get 'projects/:id/repository/:format(/*path(.:ext))', :to => 'repositories#entry', :format => /raw/ + get 'projects/:id/repository/:action(/*path(.:ext))', :controller => 'repositories', :action => /(browse|show|entry|changes|annotate|diff)/ + get 'projects/:id/repository', :to => 'repositories#show', :path => nil # additional routes for having the file name at the end of url - map.connect 'attachments/:id/:filename', :controller => 'attachments', - :action => 'show', :id => /\d+/, :filename => /.*/, - :conditions => {:method => :get} - map.connect 'attachments/download/:id/:filename', :controller => 'attachments', - :action => 'download', :id => /\d+/, :filename => /.*/, - :conditions => {:method => :get} - map.connect 'attachments/download/:id', :controller => 'attachments', - :action => 'download', :id => /\d+/, - :conditions => {:method => :get} - map.resources :attachments, :only => [:show, :destroy] - - map.resources :groups, :member => {:autocomplete_for_user => :get} - map.group_users 'groups/:id/users', :controller => 'groups', - :action => 'add_users', :id => /\d+/, - :conditions => {:method => :post} - map.group_user 'groups/:id/users/:user_id', :controller => 'groups', - :action => 'remove_user', :id => /\d+/, - :conditions => {:method => :delete} - map.connect 'groups/destroy_membership/:id', :controller => 'groups', - :action => 'destroy_membership', :id => /\d+/, - :conditions => {:method => :post} - map.connect 'groups/edit_membership/:id', :controller => 'groups', - :action => 'edit_membership', :id => /\d+/, - :conditions => {:method => :post} - - map.resources :trackers, :except => :show - map.resources :issue_statuses, :except => :show, :collection => {:update_issue_done_ratio => :post} - map.resources :custom_fields, :except => :show - map.resources :roles, :except => :show, :collection => {:permissions => [:get, :post]} - map.resources :enumerations, :except => :show - - map.connect 'projects/:id/search', :controller => 'search', :action => 'index', :conditions => {:method => :get} - map.connect 'search', :controller => 'search', :action => 'index', :conditions => {:method => :get} - - map.connect 'mail_handler', :controller => 'mail_handler', - :action => 'index', :conditions => {:method => :post} - - map.connect 'admin', :controller => 'admin', :action => 'index', - :conditions => {:method => :get} - map.connect 'admin/projects', :controller => 'admin', :action => 'projects', - :conditions => {:method => :get} - map.connect 'admin/plugins', :controller => 'admin', :action => 'plugins', - :conditions => {:method => :get} - map.connect 'admin/info', :controller => 'admin', :action => 'info', - :conditions => {:method => :get} - map.connect 'admin/test_email', :controller => 'admin', :action => 'test_email', - :conditions => {:method => :get} - map.connect 'admin/default_configuration', :controller => 'admin', - :action => 'default_configuration', :conditions => {:method => :post} - - map.resources :auth_sources, :member => {:test_connection => :get} - - map.connect 'workflows', :controller => 'workflows', - :action => 'index', :conditions => {:method => :get} - map.connect 'workflows/edit', :controller => 'workflows', - :action => 'edit', :conditions => {:method => [:get, :post]} - map.connect 'workflows/copy', :controller => 'workflows', - :action => 'copy', :conditions => {:method => [:get, :post]} - - map.connect 'settings', :controller => 'settings', - :action => 'index', :conditions => {:method => :get} - map.connect 'settings/edit', :controller => 'settings', - :action => 'edit', :conditions => {:method => [:get, :post]} - map.connect 'settings/plugin/:id', :controller => 'settings', - :action => 'plugin', :conditions => {:method => [:get, :post]} - - map.with_options :controller => 'sys' do |sys| - sys.connect 'sys/projects.:format', - :action => 'projects', - :conditions => {:method => :get} - sys.connect 'sys/projects/:id/repository.:format', - :action => 'create_project_repository', - :conditions => {:method => :post} - sys.connect 'sys/fetch_changesets', - :action => 'fetch_changesets', - :conditions => {:method => :get} + match 'attachments/:id/:filename', :controller => 'attachments', :action => 'show', :id => /\d+/, :filename => /.*/, :via => :get + match 'attachments/download/:id/:filename', :controller => 'attachments', :action => 'download', :id => /\d+/, :filename => /.*/, :via => :get + match 'attachments/download/:id', :controller => 'attachments', :action => 'download', :id => /\d+/, :via => :get + resources :attachments, :only => [:show, :destroy] + + resources :groups do + member do + get 'autocomplete_for_user' + end + end + + match 'groups/:id/users', :controller => 'groups', :action => 'add_users', :id => /\d+/, :via => :post, :as => 'group_users' + match 'groups/:id/users/:user_id', :controller => 'groups', :action => 'remove_user', :id => /\d+/, :via => :delete, :as => 'group_user' + match 'groups/destroy_membership/:id', :controller => 'groups', :action => 'destroy_membership', :id => /\d+/, :via => :post + match 'groups/edit_membership/:id', :controller => 'groups', :action => 'edit_membership', :id => /\d+/, :via => :post + + resources :trackers, :except => :show + resources :issue_statuses, :except => :show do + collection do + post 'update_issue_done_ratio' + end + end + resources :custom_fields, :except => :show + resources :roles, :except => :show do + collection do + match 'permissions', :via => [:get, :post] + end end + resources :enumerations, :except => :show - map.connect 'uploads.:format', :controller => 'attachments', :action => 'upload', :conditions => {:method => :post} + get 'projects/:id/search', :controller => 'search', :action => 'index' + get 'search', :controller => 'search', :action => 'index' - map.connect 'robots.txt', :controller => 'welcome', - :action => 'robots', :conditions => {:method => :get} + match 'mail_handler', :controller => 'mail_handler', :action => 'index', :via => :post - # Used for OpenID - map.root :controller => 'account', :action => 'login' + match 'admin', :controller => 'admin', :action => 'index', :via => :get + match 'admin/projects', :controller => 'admin', :action => 'projects', :via => :get + match 'admin/plugins', :controller => 'admin', :action => 'plugins', :via => :get + match 'admin/info', :controller => 'admin', :action => 'info', :via => :get + match 'admin/test_email', :controller => 'admin', :action => 'test_email', :via => :get + match 'admin/default_configuration', :controller => 'admin', :action => 'default_configuration', :via => :post + + resources :auth_sources do + member do + get 'test_connection' + end + end + + match 'workflows', :controller => 'workflows', :action => 'index', :via => :get + match 'workflows/edit', :controller => 'workflows', :action => 'edit', :via => [:get, :post] + match 'workflows/copy', :controller => 'workflows', :action => 'copy', :via => [:get, :post] + match 'settings', :controller => 'settings', :action => 'index', :via => :get + match 'settings/edit', :controller => 'settings', :action => 'edit', :via => [:get, :post] + match 'settings/plugin/:id', :controller => 'settings', :action => 'plugin', :via => [:get, :post] + + match 'sys/projects', :to => 'sys#projects', :via => :get + match 'sys/projects/:id/repository', :to => 'sys#create_project_repository', :via => :post + match 'sys/fetch_changesets', :to => 'sys#fetch_changesets', :via => :get + + match 'uploads', :to => 'attachments#upload', :via => :post + + get 'robots.txt', :to => 'welcome#robots' + + Dir.glob File.expand_path("plugins/*", Rails.root) do |plugin_dir| + file = File.join(plugin_dir, "config/routes.rb") + if File.exists?(file) + begin + instance_eval File.read(file) + rescue Exception => e + puts "An error occurred while loading the routes definition of #{File.basename(plugin_dir)} plugin (#{file}): #{e.message}." + exit 1 + end + end + end end |