From 8ab9215ea8df2216ccfacf272804811b05ab82c8 Mon Sep 17 00:00:00 2001 From: Jean-Philippe Lang Date: Tue, 11 Dec 2012 19:39:47 +0000 Subject: [PATCH] Use named routes in controllers. git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@10983 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- app/controllers/application_controller.rb | 10 ++++++++ app/controllers/issue_statuses_controller.rb | 10 ++++---- app/controllers/issues_controller.rb | 18 +++++++------ app/controllers/journals_controller.rb | 2 +- app/controllers/members_controller.rb | 12 ++++++--- app/controllers/my_controller.rb | 16 ++++++------ app/controllers/news_controller.rb | 6 ++--- .../project_enumerations_controller.rb | 5 ++-- app/controllers/projects_controller.rb | 25 ++++++++++--------- app/controllers/queries_controller.rb | 6 ++--- app/controllers/roles_controller.rb | 10 ++++---- app/controllers/settings_controller.rb | 4 +-- app/controllers/timelog_controller.rb | 20 ++++++++++----- app/controllers/trackers_controller.rb | 8 +++--- app/controllers/users_controller.rb | 15 +++++------ app/controllers/versions_controller.rb | 10 ++++---- app/controllers/wiki_controller.rb | 12 ++++----- app/controllers/wikis_controller.rb | 2 +- app/controllers/workflows_controller.rb | 6 ++--- config/routes.rb | 4 +-- test/functional/projects_controller_test.rb | 2 +- test/functional/settings_controller_test.rb | 2 +- 22 files changed, 117 insertions(+), 88 deletions(-) diff --git a/app/controllers/application_controller.rb b/app/controllers/application_controller.rb index a4c804fd830..2b5e2f2c29d 100644 --- a/app/controllers/application_controller.rb +++ b/app/controllers/application_controller.rb @@ -334,6 +334,16 @@ def back_url url end + # Returns the path to project issues or to the cross-project + # issue list if project is nil + def _issues_path(project, *args) + if project + project_issues_path(project, *args) + else + issues_path(*args) + end + end + def redirect_back_or_default(default) back_url = params[:back_url].to_s if back_url.present? diff --git a/app/controllers/issue_statuses_controller.rb b/app/controllers/issue_statuses_controller.rb index 13943ddf8bd..ddaf9304d28 100644 --- a/app/controllers/issue_statuses_controller.rb +++ b/app/controllers/issue_statuses_controller.rb @@ -42,7 +42,7 @@ def create @issue_status = IssueStatus.new(params[:issue_status]) if request.post? && @issue_status.save flash[:notice] = l(:notice_successful_create) - redirect_to :action => 'index' + redirect_to issue_statuses_path else render :action => 'new' end @@ -56,7 +56,7 @@ def update @issue_status = IssueStatus.find(params[:id]) if request.put? && @issue_status.update_attributes(params[:issue_status]) flash[:notice] = l(:notice_successful_update) - redirect_to :action => 'index' + redirect_to issue_statuses_path else render :action => 'edit' end @@ -64,10 +64,10 @@ def update def destroy IssueStatus.find(params[:id]).destroy - redirect_to :action => 'index' + redirect_to issue_statuses_path rescue flash[:error] = l(:error_unable_delete_issue_status) - redirect_to :action => 'index' + redirect_to issue_statuses_path end def update_issue_done_ratio @@ -76,6 +76,6 @@ def update_issue_done_ratio else flash[:error] = l(:error_issue_done_ratios_not_updated) end - redirect_to :action => 'index' + redirect_to issue_statuses_path end end diff --git a/app/controllers/issues_controller.rb b/app/controllers/issues_controller.rb index 455d2e3d565..a48ded5ee4e 100644 --- a/app/controllers/issues_controller.rb +++ b/app/controllers/issues_controller.rb @@ -145,8 +145,12 @@ def create format.html { render_attachment_warning_if_needed(@issue) flash[:notice] = l(:notice_issue_successful_create, :id => view_context.link_to("##{@issue.id}", issue_path(@issue), :title => @issue.subject)) - redirect_to(params[:continue] ? { :action => 'new', :project_id => @issue.project, :issue => {:tracker_id => @issue.tracker, :parent_issue_id => @issue.parent_issue_id}.reject {|k,v| v.nil?} } : - { :action => 'show', :id => @issue }) + if params[:continue] + attrs = {:tracker_id => @issue.tracker, :parent_issue_id => @issue.parent_issue_id}.reject {|k,v| v.nil?} + redirect_to new_project_issue_path(@issue.project, :issue => attrs) + else + redirect_to issue_path(@issue) + end } format.api { render :action => 'show', :status => :created, :location => issue_url(@issue) } end @@ -187,7 +191,7 @@ def update flash[:notice] = l(:notice_successful_update) unless @issue.current_journal.new_record? respond_to do |format| - format.html { redirect_back_or_default({:action => 'show', :id => @issue}) } + format.html { redirect_back_or_default issue_path(@issue) } format.api { render_api_ok } end else @@ -270,12 +274,12 @@ def bulk_update if params[:follow] if @issues.size == 1 && moved_issues.size == 1 - redirect_to :controller => 'issues', :action => 'show', :id => moved_issues.first + redirect_to issue_path(moved_issues.first) elsif moved_issues.map(&:project).uniq.size == 1 - redirect_to :controller => 'issues', :action => 'index', :project_id => moved_issues.map(&:project).first + redirect_to project_issues_path(moved_issues.map(&:project).first) end else - redirect_back_or_default({:controller => 'issues', :action => 'index', :project_id => @project}) + redirect_back_or_default _issues_path(@project) end end @@ -308,7 +312,7 @@ def destroy end end respond_to do |format| - format.html { redirect_back_or_default(:action => 'index', :project_id => @project) } + format.html { redirect_back_or_default _issues_path(@project) } format.api { render_api_ok } end end diff --git a/app/controllers/journals_controller.rb b/app/controllers/journals_controller.rb index 5b9624ca573..64614b9bec8 100644 --- a/app/controllers/journals_controller.rb +++ b/app/controllers/journals_controller.rb @@ -80,7 +80,7 @@ def edit @journal.destroy if @journal.details.empty? && @journal.notes.blank? call_hook(:controller_journals_edit_post, { :journal => @journal, :params => params}) respond_to do |format| - format.html { redirect_to :controller => 'issues', :action => 'show', :id => @journal.journalized_id } + format.html { redirect_to issue_path(@journal.journalized) } format.js { render :action => 'update' } end else diff --git a/app/controllers/members_controller.rb b/app/controllers/members_controller.rb index 520302c8c2f..c1f737dc947 100644 --- a/app/controllers/members_controller.rb +++ b/app/controllers/members_controller.rb @@ -63,7 +63,7 @@ def create end respond_to do |format| - format.html { redirect_to :controller => 'projects', :action => 'settings', :tab => 'members', :id => @project } + format.html { redirect_to_settings_in_projects } format.js { @members = members } format.api { @member = members.first @@ -82,7 +82,7 @@ def update end saved = @member.save respond_to do |format| - format.html { redirect_to :controller => 'projects', :action => 'settings', :tab => 'members', :id => @project } + format.html { redirect_to_settings_in_projects } format.js format.api { if saved @@ -99,7 +99,7 @@ def destroy @member.destroy end respond_to do |format| - format.html { redirect_to :controller => 'projects', :action => 'settings', :tab => 'members', :id => @project } + format.html { redirect_to_settings_in_projects } format.js format.api { if @member.destroyed? @@ -115,4 +115,10 @@ def autocomplete @principals = Principal.active.not_member_of(@project).like(params[:q]).all(:limit => 100) render :layout => false end + + private + + def redirect_to_settings_in_projects + redirect_to settings_project_path(@project, :tab => 'members') + end end diff --git a/app/controllers/my_controller.rb b/app/controllers/my_controller.rb index b2c2a9dc7fc..9ee82c0546f 100644 --- a/app/controllers/my_controller.rb +++ b/app/controllers/my_controller.rb @@ -59,7 +59,7 @@ def account @user.notified_project_ids = (@user.mail_notification == 'selected' ? params[:notified_project_ids] : []) set_language_if_valid @user.language flash[:notice] = l(:notice_account_updated) - redirect_to :action => 'account' + redirect_to my_account_path return end end @@ -69,7 +69,7 @@ def account def destroy @user = User.current unless @user.own_account_deletable? - redirect_to :action => 'account' + redirect_to my_account_path return end @@ -88,7 +88,7 @@ def password @user = User.current unless @user.change_password_allowed? flash[:error] = l(:notice_can_t_change_password) - redirect_to :action => 'account' + redirect_to my_account_path return end if request.post? @@ -96,7 +96,7 @@ def password @user.password, @user.password_confirmation = params[:new_password], params[:new_password_confirmation] if @user.save flash[:notice] = l(:notice_account_password_updated) - redirect_to :action => 'account' + redirect_to my_account_path end else flash[:error] = l(:notice_account_wrong_password) @@ -114,7 +114,7 @@ def reset_rss_key User.current.rss_key flash[:notice] = l(:notice_feeds_access_key_reseted) end - redirect_to :action => 'account' + redirect_to my_account_path end # Create a new API key @@ -127,7 +127,7 @@ def reset_api_key User.current.api_key flash[:notice] = l(:notice_api_access_key_reseted) end - redirect_to :action => 'account' + redirect_to my_account_path end # User's page layout configuration @@ -156,7 +156,7 @@ def add_block layout['top'].unshift block @user.pref[:my_page_layout] = layout @user.pref.save - redirect_to :action => 'page_layout' + redirect_to my_page_layout_path end # Remove a block to user's page @@ -169,7 +169,7 @@ def remove_block %w(top left right).each {|f| (layout[f] ||= []).delete block } @user.pref[:my_page_layout] = layout @user.pref.save - redirect_to :action => 'page_layout' + redirect_to my_page_layout_path end # Change blocks order on user's page diff --git a/app/controllers/news_controller.rb b/app/controllers/news_controller.rb index c4e83fa725a..160328ebc25 100644 --- a/app/controllers/news_controller.rb +++ b/app/controllers/news_controller.rb @@ -73,7 +73,7 @@ def create if @news.save render_attachment_warning_if_needed(@news) flash[:notice] = l(:notice_successful_create) - redirect_to :controller => 'news', :action => 'index', :project_id => @project + redirect_to project_news_index_path(@project) else render :action => 'new' end @@ -88,7 +88,7 @@ def update if @news.save render_attachment_warning_if_needed(@news) flash[:notice] = l(:notice_successful_update) - redirect_to :action => 'show', :id => @news + redirect_to news_path(@news) else render :action => 'edit' end @@ -96,7 +96,7 @@ def update def destroy @news.destroy - redirect_to :action => 'index', :project_id => @project + redirect_to project_news_index_path(@project) end private diff --git a/app/controllers/project_enumerations_controller.rb b/app/controllers/project_enumerations_controller.rb index 2254caaeef6..11273b8db57 100644 --- a/app/controllers/project_enumerations_controller.rb +++ b/app/controllers/project_enumerations_controller.rb @@ -29,7 +29,7 @@ def update flash[:notice] = l(:notice_successful_update) end - redirect_to :controller => 'projects', :action => 'settings', :tab => 'activities', :id => @project + redirect_to settings_project_path(@project, :tab => 'activities') end def destroy @@ -37,7 +37,6 @@ def destroy time_entry_activity.destroy(time_entry_activity.parent) end flash[:notice] = l(:notice_successful_update) - redirect_to :controller => 'projects', :action => 'settings', :tab => 'activities', :id => @project + redirect_to settings_project_path(@project, :tab => 'activities') end - end diff --git a/app/controllers/projects_controller.rb b/app/controllers/projects_controller.rb index 56b62263cbf..d9edffa41cd 100644 --- a/app/controllers/projects_controller.rb +++ b/app/controllers/projects_controller.rb @@ -90,10 +90,12 @@ def create respond_to do |format| format.html { flash[:notice] = l(:notice_successful_create) - redirect_to(params[:continue] ? - {:controller => 'projects', :action => 'new', :project => {:parent_id => @project.parent_id}.reject {|k,v| v.nil?}} : - {:controller => 'projects', :action => 'settings', :id => @project} - ) + if params[:continue] + attrs = {:parent_id => @project.parent_id}.reject {|k,v| v.nil?} + redirect_to new_project_path(attrs) + else + redirect_to settings_project_path(@project) + end } format.api { render :action => 'show', :status => :created, :location => url_for(:controller => 'projects', :action => 'show', :id => @project.id) } end @@ -103,7 +105,6 @@ def create format.api { render_validation_errors(@project) } end end - end def copy @@ -120,13 +121,13 @@ def copy if validate_parent_id && @project.copy(@source_project, :only => params[:only]) @project.set_allowed_parent!(params[:project]['parent_id']) if params[:project].has_key?('parent_id') flash[:notice] = l(:notice_successful_create) - redirect_to :controller => 'projects', :action => 'settings', :id => @project + redirect_to settings_project_path(@project) elsif !@project.new_record? # Project was created # But some objects were not copied due to validation failures # (eg. issues from disabled trackers) # TODO: inform about that - redirect_to :controller => 'projects', :action => 'settings', :id => @project + redirect_to settings_project_path(@project) end end end @@ -182,7 +183,7 @@ def update respond_to do |format| format.html { flash[:notice] = l(:notice_successful_update) - redirect_to :action => 'settings', :id => @project + redirect_to settings_project_path(@project) } format.api { render_api_ok } end @@ -200,7 +201,7 @@ def update def modules @project.enabled_module_names = params[:enabled_module_names] flash[:notice] = l(:notice_successful_update) - redirect_to :action => 'settings', :id => @project, :tab => 'modules' + redirect_to settings_project_path(@project, :tab => 'modules') end def archive @@ -209,12 +210,12 @@ def archive flash[:error] = l(:error_can_not_archive_project) end end - redirect_to(url_for(:controller => 'admin', :action => 'projects', :status => params[:status])) + redirect_to admin_projects_path(:status => params[:status]) end def unarchive @project.unarchive if request.post? && !@project.active? - redirect_to(url_for(:controller => 'admin', :action => 'projects', :status => params[:status])) + redirect_to admin_projects_path(:status => params[:status]) end def close @@ -233,7 +234,7 @@ def destroy if api_request? || params[:confirm] @project_to_destroy.destroy respond_to do |format| - format.html { redirect_to :controller => 'admin', :action => 'projects' } + format.html { redirect_to admin_projects_path } format.api { render_api_ok } end end diff --git a/app/controllers/queries_controller.rb b/app/controllers/queries_controller.rb index 16bc9f96327..448b4e56bcd 100644 --- a/app/controllers/queries_controller.rb +++ b/app/controllers/queries_controller.rb @@ -60,7 +60,7 @@ def create if @query.save flash[:notice] = l(:notice_successful_create) - redirect_to :controller => 'issues', :action => 'index', :project_id => @project, :query_id => @query + redirect_to _issues_path(@project, :query_id => @query) else render :action => 'new', :layout => !request.xhr? end @@ -78,7 +78,7 @@ def update if @query.save flash[:notice] = l(:notice_successful_update) - redirect_to :controller => 'issues', :action => 'index', :project_id => @project, :query_id => @query + redirect_to _issues_path(@project, :query_id => @query) else render :action => 'edit' end @@ -86,7 +86,7 @@ def update def destroy @query.destroy - redirect_to :controller => 'issues', :action => 'index', :project_id => @project, :set_filter => 1 + redirect_to _issues_path(@project, :set_filter => 1) end private diff --git a/app/controllers/roles_controller.rb b/app/controllers/roles_controller.rb index 72c9c70bfe9..292304260ed 100644 --- a/app/controllers/roles_controller.rb +++ b/app/controllers/roles_controller.rb @@ -58,7 +58,7 @@ def create @role.workflow_rules.copy(copy_from) end flash[:notice] = l(:notice_successful_create) - redirect_to :action => 'index' + redirect_to roles_path else @roles = Role.sorted.all render :action => 'new' @@ -71,7 +71,7 @@ def edit def update if request.put? and @role.update_attributes(params[:role]) flash[:notice] = l(:notice_successful_update) - redirect_to :action => 'index' + redirect_to roles_path else render :action => 'edit' end @@ -79,10 +79,10 @@ def update def destroy @role.destroy - redirect_to :action => 'index' + redirect_to roles_path rescue flash[:error] = l(:error_can_not_remove_role) - redirect_to :action => 'index' + redirect_to roles_path end def permissions @@ -94,7 +94,7 @@ def permissions role.save end flash[:notice] = l(:notice_successful_update) - redirect_to :action => 'index' + redirect_to roles_path end end diff --git a/app/controllers/settings_controller.rb b/app/controllers/settings_controller.rb index b27582671fb..e3a2c6d2615 100644 --- a/app/controllers/settings_controller.rb +++ b/app/controllers/settings_controller.rb @@ -36,7 +36,7 @@ def edit Setting[name] = value end flash[:notice] = l(:notice_successful_update) - redirect_to :action => 'edit', :tab => params[:tab] + redirect_to settings_path(:tab => params[:tab]) else @options = {} user_format = User::USER_FORMATS.collect{|key, value| [key, value[:setting_order]]}.sort{|a, b| a[1] <=> b[1]} @@ -55,7 +55,7 @@ def plugin if request.post? Setting.send "plugin_#{@plugin.id}=", params[:settings] flash[:notice] = l(:notice_successful_update) - redirect_to :action => 'plugin', :id => @plugin.id + redirect_to plugin_settings_path(@plugin.id) else @partial = @plugin.settings[:partial] @settings = Setting.send "plugin_#{@plugin.id}" diff --git a/app/controllers/timelog_controller.rb b/app/controllers/timelog_controller.rb index 61d72e3f3d3..eb9f7ead9e3 100644 --- a/app/controllers/timelog_controller.rb +++ b/app/controllers/timelog_controller.rb @@ -128,16 +128,24 @@ def create flash[:notice] = l(:notice_successful_create) if params[:continue] if params[:project_id] - redirect_to :action => 'new', :project_id => @time_entry.project, :issue_id => @time_entry.issue, + options = { :time_entry => {:issue_id => @time_entry.issue_id, :activity_id => @time_entry.activity_id}, :back_url => params[:back_url] + } + if @time_entry.issue + redirect_to new_project_issue_time_entry_path(@time_entry.project, @time_entry.issue, options) + else + redirect_to new_project_time_entry_path(@time_entry.project, options) + end else - redirect_to :action => 'new', + options = { :time_entry => {:project_id => @time_entry.project_id, :issue_id => @time_entry.issue_id, :activity_id => @time_entry.activity_id}, :back_url => params[:back_url] + } + redirect_to new_time_entry_path(options) end else - redirect_back_or_default :action => 'index', :project_id => @time_entry.project + redirect_back_or_default project_time_entries_path(@time_entry.project) end } format.api { render :action => 'show', :status => :created, :location => time_entry_url(@time_entry) } @@ -163,7 +171,7 @@ def update respond_to do |format| format.html { flash[:notice] = l(:notice_successful_update) - redirect_back_or_default :action => 'index', :project_id => @time_entry.project + redirect_back_or_default project_time_entries_path(@time_entry.project) } format.api { render_api_ok } end @@ -194,7 +202,7 @@ def bulk_update end end set_flash_from_bulk_time_entry_save(@time_entries, unsaved_time_entry_ids) - redirect_back_or_default({:controller => 'timelog', :action => 'index', :project_id => @projects.first}) + redirect_back_or_default project_time_entries_path(@projects.first) end def destroy @@ -213,7 +221,7 @@ def destroy else flash[:error] = l(:notice_unable_delete_time_entry) end - redirect_back_or_default(:action => 'index', :project_id => @projects.first) + redirect_back_or_default project_time_entries_path(@projects.first) } format.api { if destroyed diff --git a/app/controllers/trackers_controller.rb b/app/controllers/trackers_controller.rb index 938e6e2bc4e..602ea528846 100644 --- a/app/controllers/trackers_controller.rb +++ b/app/controllers/trackers_controller.rb @@ -48,7 +48,7 @@ def create @tracker.workflow_rules.copy(copy_from) end flash[:notice] = l(:notice_successful_create) - redirect_to :action => 'index' + redirect_to trackers_path return end new @@ -64,7 +64,7 @@ def update @tracker = Tracker.find(params[:id]) if @tracker.update_attributes(params[:tracker]) flash[:notice] = l(:notice_successful_update) - redirect_to :action => 'index' + redirect_to trackers_path return end edit @@ -78,7 +78,7 @@ def destroy else @tracker.destroy end - redirect_to :action => 'index' + redirect_to trackers_path end def fields @@ -92,7 +92,7 @@ def fields end end flash[:notice] = l(:notice_successful_update) - redirect_to :action => 'fields' + redirect_to fields_trackers_path return end @trackers = Tracker.sorted.all diff --git a/app/controllers/users_controller.rb b/app/controllers/users_controller.rb index e6702a97197..96c46fa36b0 100644 --- a/app/controllers/users_controller.rb +++ b/app/controllers/users_controller.rb @@ -101,10 +101,11 @@ def create respond_to do |format| format.html { flash[:notice] = l(:notice_user_successful_create, :id => view_context.link_to(@user.login, user_path(@user))) - redirect_to(params[:continue] ? - {:controller => 'users', :action => 'new'} : - {:controller => 'users', :action => 'edit', :id => @user} - ) + if params[:continue] + redirect_to new_user_path + else + redirect_to edit_user_path(@user) + end } format.api { render :action => 'show', :status => :created, :location => user_url(@user) } end @@ -171,7 +172,7 @@ def update def destroy @user.destroy respond_to do |format| - format.html { redirect_back_or_default(users_url) } + format.html { redirect_back_or_default(users_path) } format.api { render_api_ok } end end @@ -180,7 +181,7 @@ def edit_membership @membership = Member.edit_membership(params[:membership_id], params[:membership], @user) @membership.save respond_to do |format| - format.html { redirect_to :controller => 'users', :action => 'edit', :id => @user, :tab => 'memberships' } + format.html { redirect_to edit_user_path(@user, :tab => 'memberships') } format.js end end @@ -191,7 +192,7 @@ def destroy_membership @membership.destroy end respond_to do |format| - format.html { redirect_to :controller => 'users', :action => 'edit', :id => @user, :tab => 'memberships' } + format.html { redirect_to edit_user_path(@user, :tab => 'memberships') } format.js end end diff --git a/app/controllers/versions_controller.rb b/app/controllers/versions_controller.rb index 9777c053787..97f02e76da9 100644 --- a/app/controllers/versions_controller.rb +++ b/app/controllers/versions_controller.rb @@ -96,7 +96,7 @@ def create respond_to do |format| format.html do flash[:notice] = l(:notice_successful_create) - redirect_back_or_default :controller => 'projects', :action => 'settings', :tab => 'versions', :id => @project + redirect_back_or_default settings_project_path(@project, :tab => 'versions') end format.js format.api do @@ -125,7 +125,7 @@ def update respond_to do |format| format.html { flash[:notice] = l(:notice_successful_update) - redirect_back_or_default :controller => 'projects', :action => 'settings', :tab => 'versions', :id => @project + redirect_back_or_default settings_project_path(@project, :tab => 'versions') } format.api { render_api_ok } end @@ -142,21 +142,21 @@ def close_completed if request.put? @project.close_completed_versions end - redirect_to :controller => 'projects', :action => 'settings', :tab => 'versions', :id => @project + redirect_to settings_project_path(@project, :tab => 'versions') end def destroy if @version.fixed_issues.empty? @version.destroy respond_to do |format| - format.html { redirect_back_or_default :controller => 'projects', :action => 'settings', :tab => 'versions', :id => @project } + format.html { redirect_back_or_default settings_project_path(@project, :tab => 'versions') } format.api { render_api_ok } end else respond_to do |format| format.html { flash[:error] = l(:notice_unable_delete_version) - redirect_to :controller => 'projects', :action => 'settings', :tab => 'versions', :id => @project + redirect_to settings_project_path(@project, :tab => 'versions') } format.api { head :unprocessable_entity } end diff --git a/app/controllers/wiki_controller.rb b/app/controllers/wiki_controller.rb index 115f611575c..6d3b4463684 100644 --- a/app/controllers/wiki_controller.rb +++ b/app/controllers/wiki_controller.rb @@ -160,10 +160,10 @@ def update call_hook(:controller_wiki_edit_after_save, { :params => params, :page => @page}) respond_to do |format| - format.html { redirect_to :action => 'show', :project_id => @project, :id => @page.title } + format.html { redirect_to project_wiki_page_path(@project, @page.title) } format.api { if was_new_page - render :action => 'show', :status => :created, :location => url_for(:controller => 'wiki', :action => 'show', :project_id => @project, :id => @page.title) + render :action => 'show', :status => :created, :location => project_wiki_page_path(@project, @page.title) else render_api_ok end @@ -200,13 +200,13 @@ def rename @original_title = @page.pretty_title if request.post? && @page.update_attributes(params[:wiki_page]) flash[:notice] = l(:notice_successful_update) - redirect_to :action => 'show', :project_id => @project, :id => @page.title + redirect_to project_wiki_page_path(@project, @page.title) end end def protect @page.update_attribute :protected, params[:protected] - redirect_to :action => 'show', :project_id => @project, :id => @page.title + redirect_to project_wiki_page_path(@project, @page.title) end # show page history @@ -262,7 +262,7 @@ def destroy end @page.destroy respond_to do |format| - format.html { redirect_to :action => 'index', :project_id => @project } + format.html { redirect_to project_wiki_index_path(@project) } format.api { render_api_ok } end end @@ -272,7 +272,7 @@ def destroy_version @content = @page.content_for_version(params[:version]) @content.destroy - redirect_to_referer_or :action => 'history', :id => @page.title, :project_id => @project + redirect_to_referer_or history_project_wiki_page_path(@project, @page.title) end # Export wiki to a single pdf or html file diff --git a/app/controllers/wikis_controller.rb b/app/controllers/wikis_controller.rb index 5f40bb9343e..05ef52f5edf 100644 --- a/app/controllers/wikis_controller.rb +++ b/app/controllers/wikis_controller.rb @@ -30,7 +30,7 @@ def edit def destroy if request.post? && params[:confirm] && @project.wiki @project.wiki.destroy - redirect_to :controller => 'projects', :action => 'settings', :id => @project, :tab => 'wiki' + redirect_to settings_project_path(@project, :tab => 'wiki') end end end diff --git a/app/controllers/workflows_controller.rb b/app/controllers/workflows_controller.rb index 79363566780..16fe75d1658 100644 --- a/app/controllers/workflows_controller.rb +++ b/app/controllers/workflows_controller.rb @@ -38,7 +38,7 @@ def edit } } if @role.save - redirect_to :action => 'edit', :role_id => @role, :tracker_id => @tracker, :used_statuses_only => params[:used_statuses_only] + redirect_to workflows_edit_path(:role_id => @role, :tracker_id => @tracker, :used_statuses_only => params[:used_statuses_only]) return end end @@ -64,7 +64,7 @@ def permissions if request.post? && @role && @tracker WorkflowPermission.replace_permissions(@tracker, @role, params[:permissions] || {}) - redirect_to :action => 'permissions', :role_id => @role, :tracker_id => @tracker, :used_statuses_only => params[:used_statuses_only] + redirect_to workflows_permissions_path(:role_id => @role, :tracker_id => @tracker, :used_statuses_only => params[:used_statuses_only]) return end @@ -111,7 +111,7 @@ def copy else WorkflowRule.copy(@source_tracker, @source_role, @target_trackers, @target_roles) flash[:notice] = l(:notice_successful_update) - redirect_to :action => 'copy', :source_tracker_id => @source_tracker, :source_role_id => @source_role + redirect_to workflows_copy_path(:source_tracker_id => @source_tracker, :source_role_id => @source_role) end end end diff --git a/config/routes.rb b/config/routes.rb index 7b048d57013..14bf9ed40f6 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -141,7 +141,7 @@ end match 'wiki/index', :controller => 'wiki', :action => 'index', :via => :get - resources :wiki, :except => [:index, :new, :create] do + resources :wiki, :except => [:index, :new, :create], :as => 'wiki_page' do member do get 'rename' post 'rename' @@ -317,7 +317,7 @@ 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 'settings/plugin/:id', :controller => 'settings', :action => 'plugin', :via => [:get, :post], :as => 'plugin_settings' match 'sys/projects', :to => 'sys#projects', :via => :get match 'sys/projects/:id/repository', :to => 'sys#create_project_repository', :via => :post diff --git a/test/functional/projects_controller_test.rb b/test/functional/projects_controller_test.rb index ac9312ca88c..4bdd2095469 100644 --- a/test/functional/projects_controller_test.rb +++ b/test/functional/projects_controller_test.rb @@ -184,7 +184,7 @@ def test_index_atom assert_difference 'Project.count' do post :create, :project => {:name => "blog", :identifier => "blog"}, :continue => 'Create and continue' end - assert_redirected_to '/projects/new?' + assert_redirected_to '/projects/new' end end diff --git a/test/functional/settings_controller_test.rb b/test/functional/settings_controller_test.rb index 94f199f1b4a..71c11cc9929 100644 --- a/test/functional/settings_controller_test.rb +++ b/test/functional/settings_controller_test.rb @@ -72,7 +72,7 @@ def test_post_edit_notifications :notified_events => %w(issue_added issue_updated news_added), :emails_footer => 'Test footer' } - assert_redirected_to '/settings/edit' + assert_redirected_to '/settings' assert_equal 'functional@test.foo', Setting.mail_from assert !Setting.bcc_recipients? assert_equal %w(issue_added issue_updated news_added), Setting.notified_events