views:

6322

answers:

6

After I generate a scaffold, Rails gives me the ability to POST to items.xml which will create a new item. A GET to items.xml will simply list them all. Where does Rails specify which method in the controller (create or index, respectively) will be called, based on the type of action I am performing?

More specifically, POST calls methodA but GET to the same URL calls methodB. Where is this specified? Where does Rails make the determination to call the index method of the controller?

+19  A: 

I believe it's specified by REST. Here's a list for ya:

GET    /items        #=> index
GET    /items/1      #=> show
GET    /items/new    #=> new
GET    /items/1/edit #=> edit
PUT    /items/1      #=> update
POST   /items        #=> create
DELETE /items/1      #=> destroy

Edited to add to get all those routes, in config/routes.rb, simply add map.resources :items

Matt Grande
Just type "rake routes" to see what's up.
Horace Loeb
And is there a way to explicitly specify that I want to use POST only like in ASP.NET MVC ([HttPost] attribute)?
Alex
If you perform a GET to /items, you will go to the Index action. If you POST to /items, you will go to Create.
Matt Grande
+5  A: 

You want to look at conf/routes.rb, as well as the following two bits of the API:

http://api.rubyonrails.org/classes/ActionController/Routing.html

http://api.rubyonrails.org/classes/ActionController/AbstractRequest.html

Don Werve
The links are not valid anymore.
True Soft
+3  A: 

Like Don Werve said, take a look at your routes.rb file. In there you probably have something like this:

map.resources :items

This is where rails links the POST and GET requests to certain actions. To see how this works look at the links from the other answers. The docs help a ton.

To all the routes and which actions they link to you can type rake routes into the command prompt when you are in the root of your rails directory. This will show you everything (in terms of routing) that a scaffold gives you.

vrish88
+2  A: 

This will help a lot, but it's not a direct answer to your question. The following command will list the mappings your app uses so you don't have to remember all the details or guess.

$ rake routes

To answer more directly, this is a convention that rails uses. You set this mapping up when you put something like the following in your routes.rb

map.resources :items
jshen
+4  A: 

Rails defines seven controller methods for RESTful resources by convention. They are:

Action   HTTP Method  Purpose
-------------------------------------------------------------------------
index    GET          Displays a collection of resources
show     GET          Displays a single resource
new      GET          Displays a form for creating a new resource
create   POST         Creates a new resource (new submits to this)
edit     GET          Displays a form for editing an existing resource
update   PUT          Updates an existing resource (edit submits to this)
destroy  DELETE       Destroys a single resource

Note that because web browsers generally only support GET and POST, Rails uses a hidden field to turn these into PUT and DELETE requests as appropriate.

Specifying map.resources :items in config/routes.rb gets you those seven methods "for free". You can list all the routes within your application at any time by entering rake routes in the console.

John Topley
+1  A: 

map.resources is a method that automagically gives you the REST routes and path helpers as well. This is a nice feature if you already know and understand how rails' restful routing works but it is also a bit of a hindrance for learning rails because too much is hidden.

Railsguides has a nice routes guide.

srboisvert