Railties – Gluing the Engine to the Rails
Railties is responsible for gluing all frameworks together. Overall, it:
-
handles the bootstrapping process for a Rails application;
-
manages the
railscommand line interface; -
and provides the Rails generators core.
Download
The latest version of Railties can be installed with RubyGems:
-
gem install railties
Source code can be downloaded as part of the Rails project on GitHub
License
Railties is released under the MIT license:
Support
API documentation is at
Bug reports can be filed for the Ruby on Rails project here:
Feature requests should be discussed on the rubyonrails-core forum here:
Namespace
Module
- Rails::API
- Rails::Command
- Rails::Configuration
- Rails::Generators
- Rails::Info
- Rails::Initializable
- Rails::Paths
- Rails::Rack
- Rails::VERSION
Class
- Rails::AppBuilder
- Rails::Application
- Rails::CodeStatistics
- Rails::Console
- Rails::DBConsole
- Rails::Engine
- Rails::HealthController
- Rails::PluginBuilder
- Rails::Railtie
- Rails::Server
- Rails::SourceAnnotationExtractor
Methods
- application
- autoloaders
- backtrace_cleaner
- configuration
- env
- env=
- error
- event
- gem_version
- groups
- public_path
- root
- version
Attributes
| [RW] | app_class | |
| [W] | application | |
| [RW] | cache | |
| [RW] | logger |
Class Public methods
application()
📝 Source code
# File railties/lib/rails.rb, line 44
def application
@application ||= (app_class.instance if app_class)
end
🔎 See on GitHub
autoloaders()
📝 Source code
# File railties/lib/rails.rb, line 133
def autoloaders
application.autoloaders
end
🔎 See on GitHub
backtrace_cleaner()
📝 Source code
# File railties/lib/rails.rb, line 55
def backtrace_cleaner
@backtrace_cleaner ||= Rails::BacktraceCleaner.new
end
🔎 See on GitHub
configuration()
The Configuration instance used to configure the Rails environment
📝 Source code
# File railties/lib/rails.rb, line 51
def configuration
application.config
end
🔎 See on GitHub
env()
Returns the current Rails environment.
Rails.env # => "development"
Rails.env.development? # => true
Rails.env.production? # => false
Rails.env.local? # => true true for "development" and "test", false for anything else
📝 Source code
# File railties/lib/rails.rb, line 74
def env
@_env ||= ActiveSupport::EnvironmentInquirer.new(ENV["RAILS_ENV"].presence || ENV["RACK_ENV"].presence || "development")
end
🔎 See on GitHub
env=(environment)
Sets the Rails environment.
Rails.env = "staging" # => "staging"
📝 Source code
# File railties/lib/rails.rb, line 81
def env=(environment)
@_env = ActiveSupport::EnvironmentInquirer.new(environment)
end
🔎 See on GitHub
error()
Returns the ActiveSupport::ErrorReporter of the current Rails project, otherwise it returns nil if there is no project.
Rails.error.handle(IOError) do
# ...
end
Rails.error.report(error)
📝 Source code
# File railties/lib/rails.rb, line 92
def error
ActiveSupport.error_reporter
end
🔎 See on GitHub
event()
Returns the ActiveSupport::EventReporter of the current Rails project, otherwise it returns nil if there is no project.
Rails.event.notify("my_event", { message: "Hello, world!" })
📝 Source code
# File railties/lib/rails.rb, line 100
def event
ActiveSupport.event_reporter
end
🔎 See on GitHub
gem_version()
Returns the currently loaded version of Rails as a Gem::Version.
📝 Source code
# File railties/lib/rails/gem_version.rb, line 5
def self.gem_version
Gem::Version.new VERSION::STRING
end
🔎 See on GitHub
groups(*groups)
Returns all Rails groups for loading based on:
-
The Rails environment;
-
The environment variable RAILS_GROUPS;
-
The optional envs given as argument and the hash with group dependencies;
Rails.groups assets: [:development, :test]
# => [:default, "development", :assets] for Rails.env == "development"
# => [:default, "production"] for Rails.env == "production"
📝 Source code
# File railties/lib/rails.rb, line 113
def groups(*groups)
hash = groups.extract_options!
env = Rails.env
groups.unshift(:default, env)
groups.concat ENV["RAILS_GROUPS"].to_s.split(",")
groups.concat hash.map { |k, v| k if v.map(&:to_s).include?(env) }
groups.compact!
groups.uniq!
groups
end
🔎 See on GitHub
public_path()
Returns a Pathname object of the public folder of the current Rails project, otherwise it returns nil if there is no project:
Rails.public_path
# => #<Pathname:/Users/someuser/some/path/project/public>
📝 Source code
# File railties/lib/rails.rb, line 129
def public_path
application && Pathname.new(application.paths["public"].first)
end
🔎 See on GitHub
root()
Returns a Pathname object of the current Rails project, otherwise it returns nil if there is no project:
Rails.root
# => #<Pathname:/Users/someuser/some/path/project>
📝 Source code
# File railties/lib/rails.rb, line 64
def root
application && application.config.root
end
🔎 See on GitHub
version()
Returns the currently loaded version of Rails as a string.
📝 Source code
# File railties/lib/rails/version.rb, line 7
def self.version
VERSION::STRING
end
🔎 See on GitHub
Definition files
- railties/lib/rails.rb
- railties/lib/rails/api/task.rb
- railties/lib/rails/app_loader.rb
- railties/lib/rails/application.rb
- railties/lib/rails/application/bootstrap.rb
- railties/lib/rails/application/configuration.rb
- railties/lib/rails/application/default_middleware_stack.rb
- railties/lib/rails/application/finisher.rb
- railties/lib/rails/application/routes_reloader.rb
- railties/lib/rails/application_controller.rb
- railties/lib/rails/autoloaders.rb
- railties/lib/rails/autoloaders/inflector.rb
- railties/lib/rails/backtrace_cleaner.rb
- railties/lib/rails/cli.rb
- railties/lib/rails/code_statistics.rb
- railties/lib/rails/code_statistics_calculator.rb
- railties/lib/rails/command.rb
- railties/lib/rails/command/actions.rb
- railties/lib/rails/command/base.rb
- railties/lib/rails/command/behavior.rb
- railties/lib/rails/command/environment_argument.rb
- railties/lib/rails/command/helpers/editor.rb
- railties/lib/rails/commands.rb
- railties/lib/rails/commands/about/about_command.rb
- railties/lib/rails/commands/app/update_command.rb
- railties/lib/rails/commands/application/application_command.rb
- railties/lib/rails/commands/boot/boot_command.rb
- railties/lib/rails/commands/console/console_command.rb
- railties/lib/rails/commands/console/irb_console.rb
- railties/lib/rails/commands/credentials/credentials_command.rb
- railties/lib/rails/commands/credentials/credentials_command/diffing.rb
- railties/lib/rails/commands/db/system/change/change_command.rb
- railties/lib/rails/commands/dbconsole/dbconsole_command.rb
- railties/lib/rails/commands/destroy/destroy_command.rb
- railties/lib/rails/commands/dev/dev_command.rb
- railties/lib/rails/commands/devcontainer/devcontainer_command.rb
- railties/lib/rails/commands/encrypted/encrypted_command.rb
- railties/lib/rails/commands/gem_help/gem_help_command.rb
- railties/lib/rails/commands/generate/generate_command.rb
- railties/lib/rails/commands/help/help_command.rb
- railties/lib/rails/commands/initializers/initializers_command.rb
- railties/lib/rails/commands/middleware/middleware_command.rb
- railties/lib/rails/commands/new/new_command.rb
- railties/lib/rails/commands/notes/notes_command.rb
- railties/lib/rails/commands/plugin/plugin_command.rb
- railties/lib/rails/commands/rake/rake_command.rb
- railties/lib/rails/commands/restart/restart_command.rb
- railties/lib/rails/commands/routes/routes_command.rb
- railties/lib/rails/commands/runner/runner_command.rb
- railties/lib/rails/commands/secret/secret_command.rb
- railties/lib/rails/commands/server/server_command.rb
- railties/lib/rails/commands/stats/stats_command.rb
- railties/lib/rails/commands/test/test_command.rb
- railties/lib/rails/commands/unused_routes/unused_routes_command.rb
- railties/lib/rails/commands/version/version_command.rb
- railties/lib/rails/configuration.rb
- railties/lib/rails/deprecator.rb
- railties/lib/rails/dev_caching.rb
- railties/lib/rails/engine.rb
- railties/lib/rails/engine/configuration.rb
- railties/lib/rails/engine/railties.rb
- railties/lib/rails/engine/updater.rb
- railties/lib/rails/gem_version.rb
- railties/lib/rails/generators.rb
- railties/lib/rails/generators/actions.rb
- railties/lib/rails/generators/actions/create_migration.rb
- railties/lib/rails/generators/active_model.rb
- railties/lib/rails/generators/app_base.rb
- railties/lib/rails/generators/app_name.rb
- railties/lib/rails/generators/base.rb
- railties/lib/rails/generators/bundle_helper.rb
- railties/lib/rails/generators/database.rb
- railties/lib/rails/generators/generated_attribute.rb
- railties/lib/rails/generators/migration.rb
- railties/lib/rails/generators/model_helpers.rb
- railties/lib/rails/generators/named_base.rb
- railties/lib/rails/generators/rails/app/app_generator.rb
- railties/lib/rails/generators/rails/application_record/application_record_generator.rb
- railties/lib/rails/generators/rails/authentication/authentication_generator.rb
- railties/lib/rails/generators/rails/benchmark/benchmark_generator.rb
- railties/lib/rails/generators/rails/controller/controller_generator.rb
- railties/lib/rails/generators/rails/credentials/credentials_generator.rb
- railties/lib/rails/generators/rails/db/system/change/change_generator.rb
- railties/lib/rails/generators/rails/devcontainer/devcontainer_generator.rb
- railties/lib/rails/generators/rails/encrypted_file/encrypted_file_generator.rb
- railties/lib/rails/generators/rails/encryption_key_file/encryption_key_file_generator.rb
- railties/lib/rails/generators/rails/generator/generator_generator.rb
- railties/lib/rails/generators/rails/helper/helper_generator.rb
- railties/lib/rails/generators/rails/integration_test/integration_test_generator.rb
- railties/lib/rails/generators/rails/master_key/master_key_generator.rb
- railties/lib/rails/generators/rails/migration/migration_generator.rb
- railties/lib/rails/generators/rails/model/model_generator.rb
- railties/lib/rails/generators/rails/plugin/plugin_generator.rb
- railties/lib/rails/generators/rails/resource/resource_generator.rb
- railties/lib/rails/generators/rails/resource_route/resource_route_generator.rb
- railties/lib/rails/generators/rails/scaffold/scaffold_generator.rb
- railties/lib/rails/generators/rails/scaffold_controller/scaffold_controller_generator.rb
- railties/lib/rails/generators/rails/script/script_generator.rb
- railties/lib/rails/generators/rails/system_test/system_test_generator.rb
- railties/lib/rails/generators/rails/task/task_generator.rb
- railties/lib/rails/generators/resource_helpers.rb
- railties/lib/rails/generators/test_case.rb
- railties/lib/rails/generators/testing/assertions.rb
- railties/lib/rails/generators/testing/behavior.rb
- railties/lib/rails/generators/testing/setup_and_teardown.rb
- railties/lib/rails/health_controller.rb
- railties/lib/rails/info.rb
- railties/lib/rails/info_controller.rb
- railties/lib/rails/initializable.rb
- railties/lib/rails/mailers_controller.rb
- railties/lib/rails/paths.rb
- railties/lib/rails/plugin/test.rb
- railties/lib/rails/pwa_controller.rb
- railties/lib/rails/rack.rb
- railties/lib/rails/rack/logger.rb
- railties/lib/rails/rack/silence_request.rb
- railties/lib/rails/railtie.rb
- railties/lib/rails/railtie/configurable.rb
- railties/lib/rails/railtie/configuration.rb
- railties/lib/rails/source_annotation_extractor.rb
- railties/lib/rails/version.rb
- railties/lib/rails/welcome_controller.rb
- railties/lib/rails/zeitwerk_checker.rb