Module: ActionController::UrlFor
Relationships & Source Files | |
Extension / Inclusion / Inheritance Descendants | |
Included In:
API ,
Base ,
Redirecting ,
::ActionView::TestCase::TestController ,
Rails::ApplicationController,
Rails::InfoController,
Rails::MailersController,
Rails::WelcomeController
| |
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
self,
::ActiveSupport::Concern
|
|
Instance Chain:
|
|
Defined in: | actionpack/lib/action_controller/metal/url_for.rb |
Overview
Includes url_for
into the host class. The class has to provide a RouteSet
by implementing the _routes
method. Otherwise, an exception will be raised.
In addition to ::AbstractController::UrlFor
, this module accesses the HTTP layer to define URL options like the host
. In order to do so, this module requires the host class to implement env
which needs to be Rack-compatible and request
which is either an instance of ::ActionDispatch::Request
or an object that responds to the host
, optional_port
, protocol
and symbolized_path_parameter
methods.
class RootUrl
include ActionController::UrlFor
include Rails.application.routes.url_helpers
delegate :env, :request, to: :controller
def initialize(controller)
@controller = controller
@url = root_path # named route from the application.
end
end
Class Method Summary
::ActiveSupport::Concern
- Extended
Instance Attribute Summary
Instance Method Summary
::AbstractController::UrlFor
- Included
::ActionDispatch::Routing::UrlFor
- Included
#initialize, | |
#route_for | Allows calling direct or regular named route. |
#url_for | Generate a URL based on the options provided, default_url_options and the routes defined in routes.rb. |
#url_options | Hook overridden in controller to add request information with |
#_routes_context, #_with_routes |
::ActionDispatch::Routing::PolymorphicRoutes
- Included
#polymorphic_path | Returns the path component of a URL for the given record. |
#polymorphic_url | Constructs a call to a named RESTful route for the given record and returns the resulting URL string. |
Instance Method Details
#url_options
[ GitHub ]# File 'actionpack/lib/action_controller/metal/url_for.rb', line 30
def @_url_options ||= { host: request.host, port: request.optional_port, protocol: request.protocol, _recall: request.path_parameters }.merge!(super).freeze if (same_origin = _routes.equal?(request.routes)) || (script_name = request.engine_script_name(_routes)) || (original_script_name = request.original_script_name) = @_url_options.dup if original_script_name [:original_script_name] = original_script_name else if same_origin [:script_name] = request.script_name.empty? ? "".freeze : request.script_name.dup else [:script_name] = script_name end end .freeze else @_url_options end end