aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorScott Johnson <7.scott.j@gmail.com>2012-05-11 13:42:37 -0500
committerScott Johnson <7.scott.j@gmail.com>2012-05-11 13:48:34 -0500
commita0d9b7903588cd988c8c9b4164494c792344f43e (patch)
tree2866d4ab21f69147c9071d1748cbef58d8478b43
parent39c483fec56b98b0cdb11b705cd7e63b43d60a64 (diff)
downloadrails-a0d9b7903588cd988c8c9b4164494c792344f43e.tar.gz
rails-a0d9b7903588cd988c8c9b4164494c792344f43e.tar.bz2
rails-a0d9b7903588cd988c8c9b4164494c792344f43e.zip
update engines guide to show how to have an engine's ApplicationController inherit from the main application's ApplicationController
-rw-r--r--guides/source/engines.textile15
1 files changed, 15 insertions, 0 deletions
diff --git a/guides/source/engines.textile b/guides/source/engines.textile
index 71bcf6b713..b94ede44c4 100644
--- a/guides/source/engines.textile
+++ b/guides/source/engines.textile
@@ -448,6 +448,8 @@ rake db:migrate SCOPE=blorgh VERSION=0
h4. Using a class provided by the application
+h5. Using a model provided by the application
+
When an engine is created, it may want to use specific classes from an application to provide links between the pieces of the engine and the pieces of the application. In the case of the +blorgh+ engine, making posts and comments have authors would make a lot of sense.
Usually, an application would have a +User+ class that would provide the objects that would represent the posts' and comments' authors, but there could be a case where the application calls this class something different, such as +Person+. It's because of this reason that the engine should not hardcode the associations to be exactly for a +User+ class, but should allow for some flexibility around what the class is called.
@@ -544,6 +546,19 @@ end
Now instead of the ugly Ruby object output the author's name will be displayed.
+h5. Using a controller provided by the application
+
+Because Rails controllers generally share code for for things like authentication and accessing session variables, by default they inherit from ApplicationController. Rails engines, however are scoped to run independently from the main application, so each engine gets a scoped ApplicationController. This namespace prevents code collisions, but often engine controllers should access methods in the main application's ApplicationController. An easy way to provide this acess is to change the engine's scoped ApplicationController to inherit from the main application's ApplicationController. For our Blorgh engine this would be done by changing +app/controllers/blorgh/application_controller.rb+ to look like:
+
+<ruby>
+ class Blorgh::ApplicationController < ApplicationController
+ end
+</ruby>
+
+By default, the engine's controllers inherit from Blorgh::ApplicationController. So, after making this change they will have access to the main applications ApplicationController as though they were part of the main application.
+
+This change does require that the engine is run from a Rails application that has an ApplicationController.
+
h4. Configuring an engine
This section covers firstly how you can make the +user_class+ setting of the Blorgh engine configurable, followed by general configuration tips for the engine.