2010-04-05 04:52:47 -04:00
|
|
|
require 'active_support/core_ext/hash/reverse_merge'
|
2010-01-21 19:10:31 -05:00
|
|
|
require 'fileutils'
|
2010-01-23 16:30:17 -05:00
|
|
|
require 'rails/plugin'
|
2010-01-24 03:00:18 -05:00
|
|
|
require 'rails/engine'
|
2009-12-22 20:03:23 -05:00
|
|
|
|
2009-09-25 22:32:28 -04:00
|
|
|
module Rails
|
2010-02-02 14:05:26 -05:00
|
|
|
# In Rails 3.0, a Rails::Application object was introduced which is nothing more than
|
|
|
|
# an Engine but with the responsibility of coordinating the whole boot process.
|
|
|
|
#
|
|
|
|
# Opposite to Rails::Engine, you can only have one Rails::Application instance
|
|
|
|
# in your process and both Rails::Application and YourApplication::Application
|
|
|
|
# points to it.
|
|
|
|
#
|
|
|
|
# In other words, Rails::Application is Singleton and whenever you are accessing
|
|
|
|
# Rails::Application.config or YourApplication::Application.config, you are actually
|
|
|
|
# accessing YourApplication::Application.instance.config.
|
|
|
|
#
|
|
|
|
# == Initialization
|
|
|
|
#
|
|
|
|
# Rails::Application is responsible for executing all railties, engines and plugin
|
|
|
|
# initializers. Besides, it also executed some bootstrap initializers (check
|
|
|
|
# Rails::Application::Bootstrap) and finishing initializers, after all the others
|
|
|
|
# are executed (check Rails::Application::Finisher).
|
|
|
|
#
|
|
|
|
# == Configuration
|
|
|
|
#
|
|
|
|
# Besides providing the same configuration as Rails::Engine and Rails::Railtie,
|
|
|
|
# the application object has several specific configurations, for example
|
|
|
|
# "allow_concurrency", "cache_classes", "consider_all_requests_local", "filter_parameters",
|
|
|
|
# "logger", "metals", "reload_engines", "reload_plugins" and so forth.
|
|
|
|
#
|
|
|
|
# Check Rails::Application::Configuration to see them all.
|
|
|
|
#
|
|
|
|
# == Routes
|
|
|
|
#
|
|
|
|
# The application object is also responsible for holding the routes and reloading routes
|
|
|
|
# whenever the files change in development.
|
|
|
|
#
|
|
|
|
# == Middlewares and metals
|
|
|
|
#
|
|
|
|
# The Application is also responsible for building the middleware stack and setting up
|
|
|
|
# both application and engines metals.
|
|
|
|
#
|
2010-01-21 17:14:20 -05:00
|
|
|
class Application < Engine
|
2010-01-23 10:07:20 -05:00
|
|
|
autoload :Bootstrap, 'rails/application/bootstrap'
|
2010-01-26 08:58:00 -05:00
|
|
|
autoload :Configurable, 'rails/application/configurable'
|
2010-01-23 16:30:17 -05:00
|
|
|
autoload :Configuration, 'rails/application/configuration'
|
2010-01-23 10:07:20 -05:00
|
|
|
autoload :Finisher, 'rails/application/finisher'
|
2010-01-27 11:39:35 -05:00
|
|
|
autoload :MetalLoader, 'rails/application/metal_loader'
|
2010-01-23 10:59:32 -05:00
|
|
|
autoload :Railties, 'rails/application/railties'
|
2010-01-23 09:05:13 -05:00
|
|
|
autoload :RoutesReloader, 'rails/application/routes_reloader'
|
|
|
|
|
2009-10-08 15:14:57 -04:00
|
|
|
class << self
|
2009-12-23 20:11:17 -05:00
|
|
|
private :new
|
2010-03-08 01:34:39 -05:00
|
|
|
|
|
|
|
def configure(&block)
|
|
|
|
class_eval(&block)
|
|
|
|
end
|
2010-01-23 09:05:13 -05:00
|
|
|
|
2009-12-23 20:11:17 -05:00
|
|
|
def instance
|
2010-01-26 06:14:48 -05:00
|
|
|
if self == Rails::Application
|
|
|
|
Rails.application
|
2010-01-24 11:29:38 -05:00
|
|
|
else
|
2010-01-26 06:14:48 -05:00
|
|
|
@@instance ||= new
|
2010-01-24 11:29:38 -05:00
|
|
|
end
|
2009-11-02 20:19:03 -05:00
|
|
|
end
|
|
|
|
|
2010-01-21 17:14:20 -05:00
|
|
|
def inherited(base)
|
2010-01-24 03:00:18 -05:00
|
|
|
raise "You cannot have more than one Rails::Application" if Rails.application
|
2010-01-21 17:14:20 -05:00
|
|
|
super
|
2010-01-23 12:41:53 -05:00
|
|
|
Rails.application = base.instance
|
2009-10-08 15:14:57 -04:00
|
|
|
end
|
2009-09-28 20:57:36 -04:00
|
|
|
|
2010-01-27 15:20:32 -05:00
|
|
|
def respond_to?(*args)
|
|
|
|
super || instance.respond_to?(*args)
|
|
|
|
end
|
|
|
|
|
2010-01-23 09:05:13 -05:00
|
|
|
protected
|
|
|
|
|
|
|
|
def method_missing(*args, &block)
|
|
|
|
instance.send(*args, &block)
|
2009-12-21 21:15:27 -05:00
|
|
|
end
|
2009-11-02 20:19:03 -05:00
|
|
|
end
|
2009-09-28 20:57:36 -04:00
|
|
|
|
2010-03-26 13:47:55 -04:00
|
|
|
delegate :metal_loader, :to => :config
|
|
|
|
|
2010-01-23 12:41:53 -05:00
|
|
|
def require_environment!
|
2010-01-23 10:59:32 -05:00
|
|
|
environment = config.paths.config.environment.to_a.first
|
|
|
|
require environment if environment
|
2009-12-21 19:35:54 -05:00
|
|
|
end
|
|
|
|
|
2010-01-23 09:05:13 -05:00
|
|
|
def routes
|
2010-02-24 19:47:43 -05:00
|
|
|
@routes ||= ActionDispatch::Routing::RouteSet.new
|
2010-01-23 10:59:32 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def railties
|
|
|
|
@railties ||= Railties.new(config)
|
2009-11-02 20:19:03 -05:00
|
|
|
end
|
2009-12-14 18:54:41 -05:00
|
|
|
|
2010-01-23 09:05:13 -05:00
|
|
|
def routes_reloader
|
2010-01-27 11:39:35 -05:00
|
|
|
@routes_reloader ||= RoutesReloader.new
|
2009-12-14 18:54:41 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def reload_routes!
|
2010-01-23 09:05:13 -05:00
|
|
|
routes_reloader.reload!
|
|
|
|
end
|
2009-12-14 18:54:41 -05:00
|
|
|
|
2010-01-23 09:05:13 -05:00
|
|
|
def initialize!
|
|
|
|
run_initializers(self)
|
|
|
|
self
|
2009-12-14 18:54:41 -05:00
|
|
|
end
|
|
|
|
|
2009-12-23 20:11:17 -05:00
|
|
|
def load_tasks
|
2010-01-23 12:41:53 -05:00
|
|
|
initialize_tasks
|
2010-01-23 10:59:32 -05:00
|
|
|
super
|
|
|
|
railties.all { |r| r.load_tasks }
|
|
|
|
self
|
2009-12-23 20:11:17 -05:00
|
|
|
end
|
|
|
|
|
2010-01-19 12:43:09 -05:00
|
|
|
def load_generators
|
2010-01-23 12:41:53 -05:00
|
|
|
initialize_generators
|
2010-01-23 10:59:32 -05:00
|
|
|
super
|
|
|
|
railties.all { |r| r.load_generators }
|
|
|
|
self
|
2009-11-06 20:21:39 -05:00
|
|
|
end
|
|
|
|
|
2010-01-16 17:14:35 -05:00
|
|
|
def app
|
2010-01-23 09:05:13 -05:00
|
|
|
@app ||= middleware.build(routes)
|
2010-01-16 17:14:35 -05:00
|
|
|
end
|
|
|
|
|
2009-11-02 20:19:03 -05:00
|
|
|
def call(env)
|
2010-04-05 04:52:47 -04:00
|
|
|
app.call(env.reverse_merge!(env_defaults))
|
|
|
|
end
|
|
|
|
|
|
|
|
def env_defaults
|
|
|
|
@env_defaults ||= {
|
|
|
|
"action_dispatch.parameter_filter" => config.filter_parameters,
|
|
|
|
"action_dispatch.secret_token" => config.secret_token
|
|
|
|
}
|
2009-10-07 18:21:19 -04:00
|
|
|
end
|
|
|
|
|
2010-01-22 19:29:29 -05:00
|
|
|
def initializers
|
2010-01-25 18:08:08 -05:00
|
|
|
initializers = Bootstrap.initializers_for(self)
|
2010-01-23 10:59:32 -05:00
|
|
|
railties.all { |r| initializers += r.initializers }
|
2010-01-25 12:06:39 -05:00
|
|
|
initializers += super
|
2010-01-25 18:08:08 -05:00
|
|
|
initializers += Finisher.initializers_for(self)
|
2010-01-22 19:29:29 -05:00
|
|
|
initializers
|
|
|
|
end
|
2010-01-23 12:41:53 -05:00
|
|
|
|
|
|
|
protected
|
|
|
|
|
|
|
|
def initialize_tasks
|
|
|
|
require "rails/tasks"
|
|
|
|
task :environment do
|
|
|
|
$rails_rake_task = true
|
|
|
|
initialize!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def initialize_generators
|
|
|
|
require "rails/generators"
|
|
|
|
end
|
|
|
|
|
|
|
|
# Application is always reloadable when config.cache_classes is false.
|
|
|
|
def reloadable?(app)
|
|
|
|
true
|
|
|
|
end
|
2009-09-25 22:32:28 -04:00
|
|
|
end
|
|
|
|
end
|