AbstractController::Base is a low-level API. Nobody should be using it directly, and subclasses (like ActionController::Base) are expected to provide their own render method, since rendering means different things depending on the context.
- A
- C
- H
- I
- M
- P
- Rails START:includes
[R] | abstract |
Define a controller as abstract. See internal_methods for more details.
A list of method names that should be considered actions. This includes all public instance methods on a controller, less any internal methods (see internal_methods), adding back in any methods that are internal, but still exist on the class itself. Finally, hidden_actions are removed.
Returns
- array - A list of all methods that should be considered actions.
# File actionpack/lib/abstract_controller/base.rb, line 63 63: def action_methods 64: @action_methods ||= begin 65: # All public instance methods of this class, including ancestors 66: methods = (public_instance_methods(true) - 67: # Except for public instance methods of Base and its ancestors 68: internal_methods + 69: # Be sure to include shadowed public instance methods of this class 70: public_instance_methods(false)).uniq.map { |x| x.to_s } - 71: # And always exclude explicitly hidden actions 72: hidden_actions.to_a 73: 74: # Clear out AS callback method pollution 75: methods.reject { |method| method =~ /_one_time_conditions/ } 76: end 77: end
action_methods are cached and there is sometimes need to refresh them. clear_action_methods! allows you to do that, so next time you run action_methods, they will be recalculated
Returns the full controller name, underscored, without the ending Controller. For instance, MyApp::MyPostsController would return “my_app/my_posts“ for controller_name.
Returns
- string
The list of hidden actions to an empty array. Defaults to an empty array. This can be modified by other modules or subclasses to specify particular actions as hidden.
Returns
- array - An array of method names that should not be considered actions.
A list of all internal methods for a controller. This finds the first abstract superclass of a controller, and gets a list of all public instance methods on that abstract class. Public instance methods of a controller would normally be considered action methods, so methods declared on abstract classes are being removed. (ActionController::Metal and ActionController::Base are defined as abstract)
Returns true if a method for the action is available and can be dispatched, false otherwise.
Notice that action_methods.include?("foo") may return false and available_action?("foo") returns true because available action consider actions that are also available through other means, for example, implicit render ones.
Delegates to the class’ controller_path
Calls the action going through the entire action dispatch stack.
The actual method that is called is determined by calling method_for_action. If no method can handle the action, then an ActionNotFound error is raised.
Returns
- self
# File actionpack/lib/abstract_controller/base.rb, line 112 112: def process(action, *args) 113: @_action_name = action_name = action.to_s 114: 115: unless action_name = method_for_action(action_name) 116: raise ActionNotFound, "The action '#{action}' could not be found for #{self.class.name}" 117: end 118: 119: @_response_body = nil 120: 121: process_action(action_name, *args) 122: end