summaryrefslogtreecommitdiffstats
path: root/config
diff options
context:
space:
mode:
Diffstat (limited to 'config')
-rw-r--r--config/application.rb56
-rw-r--r--config/boot.rb126
-rw-r--r--config/environment.rb62
-rw-r--r--config/environments/development.rb25
-rw-r--r--config/environments/production.rb48
-rw-r--r--config/environments/test.rb36
-rw-r--r--config/initializers/10-patches.rb34
-rw-r--r--config/initializers/20-mime_types.rb3
-rw-r--r--config/initializers/30-redmine.rb2
-rw-r--r--config/routes.rb670
10 files changed, 436 insertions, 626 deletions
diff --git a/config/application.rb b/config/application.rb
new file mode 100644
index 000000000..4cd704139
--- /dev/null
+++ b/config/application.rb
@@ -0,0 +1,56 @@
+require File.expand_path('../boot', __FILE__)
+
+require 'rails/all'
+
+if defined?(Bundler)
+ # If you precompile assets before deploying to production, use this line
+ Bundler.require(*Rails.groups(:assets => %w(development test)))
+ # If you want your assets lazily compiled in production, use this line
+ # Bundler.require(:default, :assets, Rails.env)
+end
+
+module RedmineApp
+ class Application < Rails::Application
+ # Settings in config/environments/* take precedence over those specified here.
+ # Application configuration should go into files in config/initializers
+ # -- all .rb files in that directory are automatically loaded.
+
+ # Custom directories with classes and modules you want to be autoloadable.
+ config.autoload_paths += %W(#{config.root}/lib)
+
+ # Only load the plugins named here, in the order given (default is alphabetical).
+ # :all can be used as a placeholder for all plugins not explicitly named.
+ # config.plugins = [ :exception_notification, :ssl_requirement, :all ]
+
+ # Activate observers that should always be running.
+ config.active_record.observers = :message_observer, :issue_observer, :journal_observer, :news_observer, :document_observer, :wiki_content_observer, :comment_observer
+
+ config.active_record.store_full_sti_class = true
+
+ # Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
+ # Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
+ # config.time_zone = 'Central Time (US & Canada)'
+
+ # The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
+ # config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
+ # config.i18n.default_locale = :de
+
+ # Configure the default encoding used in templates for Ruby 1.9.
+ config.encoding = "utf-8"
+
+ # Configure sensitive parameters which will be filtered from the log file.
+ config.filter_parameters += [:password]
+
+ # Enable the asset pipeline
+ config.assets.enabled = false
+
+ # Version of your assets, change this if you want to expire all your assets
+ config.assets.version = '1.0'
+
+ config.action_mailer.perform_deliveries = false
+
+ if File.exists?(File.join(File.dirname(__FILE__), 'additional_environment.rb'))
+ instance_eval File.read(File.join(File.dirname(__FILE__), 'additional_environment.rb'))
+ end
+ end
+end
diff --git a/config/boot.rb b/config/boot.rb
index cfc60f758..4489e5868 100644
--- a/config/boot.rb
+++ b/config/boot.rb
@@ -1,124 +1,6 @@
-# Don't change this file!
-# Configure your app in config/environment.rb and config/environments/*.rb
+require 'rubygems'
-if RUBY_VERSION >= '1.9'
- require 'yaml'
- YAML::ENGINE.yamler = 'syck'
-end
+# Set up gems listed in the Gemfile.
+ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile', __FILE__)
-RAILS_ROOT = "#{File.dirname(__FILE__)}/.." unless defined?(RAILS_ROOT)
-
-module Rails
- class << self
- def boot!
- unless booted?
- preinitialize
- pick_boot.run
- end
- end
-
- def booted?
- defined? Rails::Initializer
- end
-
- def pick_boot
- (vendor_rails? ? VendorBoot : GemBoot).new
- end
-
- def vendor_rails?
- File.exist?("#{RAILS_ROOT}/vendor/rails")
- end
-
- def preinitialize
- load(preinitializer_path) if File.exist?(preinitializer_path)
- end
-
- def preinitializer_path
- "#{RAILS_ROOT}/config/preinitializer.rb"
- end
- end
-
- class Boot
- def run
- load_initializer
- Rails::Initializer.class_eval do
- def load_gems
- @bundler_loaded ||= Bundler.require :default, Rails.env
- end
- end
- Rails::Initializer.run(:set_load_path)
- end
- end
-
- class VendorBoot < Boot
- def load_initializer
- require "#{RAILS_ROOT}/vendor/rails/railties/lib/initializer"
- Rails::Initializer.run(:install_gem_spec_stubs)
- Rails::GemDependency.add_frozen_gem_path
- end
- end
-
- class GemBoot < Boot
- def load_initializer
- self.class.load_rubygems
- load_rails_gem
- require 'initializer'
- end
-
- def load_rails_gem
- if version = self.class.gem_version
- gem 'rails', version
- else
- gem 'rails'
- end
- rescue Gem::LoadError => load_error
- if load_error.message =~ /Could not find RubyGem rails/
- STDERR.puts %(Missing the Rails #{version} gem. Please `gem install -v=#{version} rails`, update your RAILS_GEM_VERSION setting in config/environment.rb for the Rails version you do have installed, or comment out RAILS_GEM_VERSION to use the latest version installed.)
- exit 1
- else
- raise
- end
- end
-
- class << self
- def rubygems_version
- Gem::RubyGemsVersion rescue nil
- end
-
- def gem_version
- if defined? RAILS_GEM_VERSION
- RAILS_GEM_VERSION
- elsif ENV.include?('RAILS_GEM_VERSION')
- ENV['RAILS_GEM_VERSION']
- else
- parse_gem_version(read_environment_rb)
- end
- end
-
- def load_rubygems
- min_version = '1.3.2'
- require 'rubygems'
- unless rubygems_version >= min_version
- $stderr.puts %Q(Rails requires RubyGems >= #{min_version} (you have #{rubygems_version}). Please `gem update --system` and try again.)
- exit 1
- end
-
- rescue LoadError
- $stderr.puts %Q(Rails requires RubyGems >= #{min_version}. Please install RubyGems and try again: http://rubygems.rubyforge.org)
- exit 1
- end
-
- def parse_gem_version(text)
- $1 if text =~ /^[^#]*RAILS_GEM_VERSION\s*=\s*["']([!~<>=]*\s*[\d.]+)["']/
- end
-
- private
- def read_environment_rb
- File.read("#{RAILS_ROOT}/config/environment.rb")
- end
- end
- end
-end
-
-# All that for this:
-Rails.boot!
+require 'bundler/setup' if File.exists?(ENV['BUNDLE_GEMFILE'])
diff --git a/config/environment.rb b/config/environment.rb
index 3da0fe490..39857ea77 100644
--- a/config/environment.rb
+++ b/config/environment.rb
@@ -1,59 +1,5 @@
-# Be sure to restart your web server when you modify this file.
+# Load the rails application
+require File.expand_path('../application', __FILE__)
-# Uncomment below to force Rails into production mode when
-# you don't control web/app server and can't set it the proper way
-# ENV['RAILS_ENV'] ||= 'production'
-
-# Bootstrap the Rails environment, frameworks, and default configuration
-require File.join(File.dirname(__FILE__), 'boot')
-
-if RUBY_VERSION >= '1.9' && defined?(Rails) && Rails::VERSION::MAJOR < 3
- Encoding.default_external = 'UTF-8'
-end
-
-# Load Engine plugin if available
-begin
- require File.join(File.dirname(__FILE__), '../vendor/plugins/engines/boot')
-rescue LoadError
- # Not available
-end
-
-Rails::Initializer.run do |config|
- # Settings in config/environments/* take precedence those specified here
-
- # Skip frameworks you're not going to use
- # config.frameworks -= [ :action_web_service, :action_mailer ]
-
- # Add additional load paths for sweepers
- config.autoload_paths += %W( #{RAILS_ROOT}/app/sweepers )
-
- # Force all environments to use the same logger level
- # (by default production uses :info, the others :debug)
- # config.log_level = :debug
-
- # Enable page/fragment caching by setting a file-based store
- # (remember to create the caching directory and make it readable to the application)
- # config.action_controller.cache_store = :file_store, "#{RAILS_ROOT}/tmp/cache"
-
- # Activate observers that should always be running
- # config.active_record.observers = :cacher, :garbage_collector
- config.active_record.observers = :message_observer, :issue_observer, :journal_observer, :news_observer, :document_observer, :wiki_content_observer, :comment_observer
-
- # Make Active Record use UTC-base instead of local time
- # config.active_record.default_timezone = :utc
-
- # Use Active Record's schema dumper instead of SQL when creating the test database
- # (enables use of different database adapters for development and test environments)
- # config.active_record.schema_format = :ruby
-
- # Deliveries are disabled by default. Do NOT modify this section.
- # Define your email configuration in configuration.yml instead.
- # It will automatically turn deliveries on
- config.action_mailer.perform_deliveries = false
-
- # Load any local configuration that is kept out of source control
- # (e.g. gems, patches).
- if File.exists?(File.join(File.dirname(__FILE__), 'additional_environment.rb'))
- instance_eval File.read(File.join(File.dirname(__FILE__), 'additional_environment.rb'))
- end
-end
+# Initialize the rails application
+RedmineApp::Application.initialize!
diff --git a/config/environments/development.rb b/config/environments/development.rb
index c816f03e3..9657d8f11 100644
--- a/config/environments/development.rb
+++ b/config/environments/development.rb
@@ -1,16 +1,19 @@
# Settings specified here will take precedence over those in config/environment.rb
+RedmineApp::Application.configure do
+ # In the development environment your application's code is reloaded on
+ # every request. This slows down response time but is perfect for development
+ # since you don't have to restart the webserver when you make code changes.
+ config.cache_classes = false
-# In the development environment your application's code is reloaded on
-# every request. This slows down response time but is perfect for development
-# since you don't have to restart the webserver when you make code changes.
-config.cache_classes = false
+ # Log error messages when you accidentally call methods on nil.
+ config.whiny_nils = true
-# Log error messages when you accidentally call methods on nil.
-config.whiny_nils = true
+ # Show full error reports and disable caching
+ #config.action_controller.consider_all_requests_local = true
+ config.action_controller.perform_caching = false
-# Show full error reports and disable caching
-config.action_controller.consider_all_requests_local = true
-config.action_controller.perform_caching = false
+ # Don't care if the mailer can't send
+ config.action_mailer.raise_delivery_errors = false
-# Don't care if the mailer can't send
-config.action_mailer.raise_delivery_errors = false
+ config.active_support.deprecation = :log
+end
diff --git a/config/environments/production.rb b/config/environments/production.rb
index 91af89ce2..9ff88560d 100644
--- a/config/environments/production.rb
+++ b/config/environments/production.rb
@@ -1,30 +1,32 @@
# Settings specified here will take precedence over those in config/environment.rb
+RedmineApp::Application.configure do
+ # The production environment is meant for finished, "live" apps.
+ # Code is not reloaded between requests
+ config.cache_classes = true
-# The production environment is meant for finished, "live" apps.
-# Code is not reloaded between requests
-config.cache_classes = true
+ #####
+ # Customize the default logger (http://ruby-doc.org/core/classes/Logger.html)
+ #
+ # Use a different logger for distributed setups
+ # config.logger = SyslogLogger.new
+ #
+ # Rotate logs bigger than 1MB, keeps no more than 7 rotated logs around.
+ # When setting a new Logger, make sure to set it's log level too.
+ #
+ # config.logger = Logger.new(config.log_path, 7, 1048576)
+ # config.logger.level = Logger::INFO
-#####
-# Customize the default logger (http://ruby-doc.org/core/classes/Logger.html)
-#
-# Use a different logger for distributed setups
-# config.logger = SyslogLogger.new
-#
-# Rotate logs bigger than 1MB, keeps no more than 7 rotated logs around.
-# When setting a new Logger, make sure to set it's log level too.
-#
-# config.logger = Logger.new(config.log_path, 7, 1048576)
-# config.logger.level = Logger::INFO
+ # Full error reports are disabled and caching is turned on
+ config.action_controller.perform_caching = true
-# Full error reports are disabled and caching is turned on
-config.action_controller.consider_all_requests_local = false
-config.action_controller.perform_caching = true
+ # Enable serving of images, stylesheets, and javascripts from an asset server
+ # config.action_controller.asset_host = "http://assets.example.com"
-# Enable serving of images, stylesheets, and javascripts from an asset server
-# config.action_controller.asset_host = "http://assets.example.com"
+ # Disable delivery errors if you bad email addresses should just be ignored
+ config.action_mailer.raise_delivery_errors = false
-# Disable delivery errors if you bad email addresses should just be ignored
-config.action_mailer.raise_delivery_errors = false
+ # No email in production log
+ config.action_mailer.logger = nil
-# No email in production log
-config.action_mailer.logger = nil
+ config.active_support.deprecation = :log
+end
diff --git a/config/environments/test.rb b/config/environments/test.rb
index 4ce45527a..39b4738b7 100644
--- a/config/environments/test.rb
+++ b/config/environments/test.rb
@@ -1,25 +1,25 @@
# Settings specified here will take precedence over those in config/environment.rb
+RedmineApp::Application.configure do
+ # The test environment is used exclusively to run your application's
+ # test suite. You never need to work with it otherwise. Remember that
+ # your test database is "scratch space" for the test suite and is wiped
+ # and recreated between test runs. Don't rely on the data there!
+ config.cache_classes = true
-# The test environment is used exclusively to run your application's
-# test suite. You never need to work with it otherwise. Remember that
-# your test database is "scratch space" for the test suite and is wiped
-# and recreated between test runs. Don't rely on the data there!
-config.cache_classes = true
+ # Log error messages when you accidentally call methods on nil.
+ config.whiny_nils = true
-# Log error messages when you accidentally call methods on nil.
-config.whiny_nils = true
+ # Show full error reports and disable caching
+ #config.action_controller.consider_all_requests_local = true
+ config.action_controller.perform_caching = false
-# Show full error reports and disable caching
-config.action_controller.consider_all_requests_local = true
-config.action_controller.perform_caching = false
+ config.action_mailer.perform_deliveries = true
+ config.action_mailer.delivery_method = :test
-config.action_mailer.perform_deliveries = true
-config.action_mailer.delivery_method = :test
+ # Skip protect_from_forgery in requests http://m.onkey.org/2007/9/28/csrf-protection-for-your-existing-rails-application
+ config.action_controller.allow_forgery_protection = false
-config.action_controller.session = {
- :key => "_test_session",
- :secret => "some secret phrase for the tests."
-}
+ config.active_support.deprecation = :log
-# Skip protect_from_forgery in requests http://m.onkey.org/2007/9/28/csrf-protection-for-your-existing-rails-application
-config.action_controller.allow_forgery_protection = false
+ config.secret_token = 'a secret token for running the tests'
+end
diff --git a/config/initializers/10-patches.rb b/config/initializers/10-patches.rb
index 959107048..484ea1fb7 100644
--- a/config/initializers/10-patches.rb
+++ b/config/initializers/10-patches.rb
@@ -8,6 +8,9 @@ require 'active_record'
module ActiveRecord
class Base
include Redmine::I18n
+ def self.named_scope(*args)
+ scope(*args)
+ end
# Translate attribute names for validation errors display
def self.human_attribute_name(attr, *args)
@@ -35,6 +38,18 @@ module ActionView
end
end
end
+
+ class Resolver
+ def find_all(name, prefix=nil, partial=false, details={}, key=nil, locals=[])
+ cached(key, [name, prefix, partial], details, locals) do
+ if details[:formats] & [:xml, :json]
+ details = details.dup
+ details[:formats] = details[:formats].dup + [:api]
+ end
+ find_templates(name, prefix, partial, details)
+ end
+ end
+ end
end
ActionView::Base.field_error_proc = Proc.new{ |html_tag, instance| "#{html_tag}" }
@@ -60,26 +75,9 @@ end
ActionMailer::Base.send :include, AsynchronousMailer
-module TMail
- # TMail::Unquoter.convert_to_with_fallback_on_iso_8859_1 introduced in TMail 1.2.7
- # triggers a test failure in test_add_issue_with_japanese_keywords(MailHandlerTest)
- class Unquoter
- class << self
- alias_method :convert_to, :convert_to_without_fallback_on_iso_8859_1
- end
- end
-
- # Patch for TMail 1.2.7. See http://www.redmine.org/issues/8751
- class Encoder
- def puts_meta(str)
- add_text str
- end
- end
-end
-
module ActionController
module MimeResponds
- class Responder
+ class Collector
def api(&block)
any(:xml, :json, &block)
end
diff --git a/config/initializers/20-mime_types.rb b/config/initializers/20-mime_types.rb
index dabac3463..cfd35a3e9 100644
--- a/config/initializers/20-mime_types.rb
+++ b/config/initializers/20-mime_types.rb
@@ -1,5 +1,4 @@
# Add new mime types for use in respond_to blocks:
Mime::SET << Mime::CSV unless Mime::SET.include?(Mime::CSV)
-Mime::Type.register 'application/pdf', :pdf
-Mime::Type.register 'image/png', :png
+
diff --git a/config/initializers/30-redmine.rb b/config/initializers/30-redmine.rb
index 708dcd655..4286081db 100644
--- a/config/initializers/30-redmine.rb
+++ b/config/initializers/30-redmine.rb
@@ -3,3 +3,5 @@ I18n.default_locale = 'en'
I18n::Backend::Simple.send(:include, I18n::Backend::Fallbacks)
require 'redmine'
+
+Redmine::Plugin.load
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