Rails3 Routing Problem - ruby-on-rails-3

I keep getting this error when trying to view a page.
ActionView::Template::Error (No route
matches {:controller=>"classifieds",
:action=>"edit", :id=>#}):
40: <%= h classified.category.name
%>
41: <%= h classified.subcategory.name
%>
42: <%= h classified.status %>
43: <%= link_to "Edit",
edit_classified_path(classified)%>
44: <%= link_to 'Destroy', classified,
:confirm => 'Are you sure?', :method
=> :delete %>
45: <%= check_box_tag 'remove[id][]',
classified.id, false %>
46:
routes file
Rails3::Application.routes.draw do
resources :main, :categories, :cities, :users, :subcategories, :classifieds
resource :user
root :to => 'main#index'
match ':controller(/:action(/:id(.:format)))'
# route for simple captcha
match '/simple_captcha/:action', :controller => 'simple_captcha'
#admin logout
match '/logout', :controller=>'users', :action=>'destroy'
match '/login', :controller=>'users', :action=>'show'
match '/adminsearch', :controller=>'classifieds', :action=>'adminsearch'
#search
match '/mainsearch', :controller=>'main', :action=>'mainsearch'
match '/:permalink_1/categorysearch', :controller=>'main', :action=>'categorysearch'
match '/contactadvertiser', :controller=>'main', :action=>'contactadvertiser'
#city page
match '/:permalink_1', :controller => 'main', :action => 'city'
match '/edit', :controller => 'cities', :action => 'edit'
#activate, edit classifieds
match '/activate/:activation_code', :controller => 'main', :action => 'activate'
match '/edit/:activation_code', :controller => 'classifieds', :action => 'edit'
match '/update/:activation_code', :controller => 'classifieds', :action => 'update'
match '/delete/:activation_code', :controller => 'classifieds', :action => 'destroy'
match '/classifieds/multidelete', :controller=>'classifieds', :action=>'delete_multiple'
#category page
match '/:permalink_1/:permalink_2', :controller => 'main', :action => 'category'
#ad page
match '/:permalink_1/:permalink_2/:permalink_3', :controller => 'classifieds', :action => 'show'
end
rake routes:
main_index GET /main(.:format) {:controller=>"main", :action=>"index"}
POST /main(.:format) {:controller=>"main", :action=>"create"}
new_main GET /main/new(.:format) {:controller=>"main", :action=>"new"}
edit_main GET /main/:id/edit(.:format) {:controller=>"main", :action=>"edit"}
main GET /main/:id(.:format) {:controller=>"main", :action=>"show"}
PUT /main/:id(.:format) {:controller=>"main", :action=>"update"}
DELETE /main/:id(.:format) {:controller=>"main", :action=>"destroy"}
categories GET /categories(.:format) {:controller=>"categories", :action=>"index"}
POST /categories(.:format) {:controller=>"categories", :action=>"create"}
new_category GET /categories/new(.:format) {:controller=>"categories", :action=>"new"}
edit_category GET /categories/:id/edit(.:format) {:controller=>"categories", :action=>"edit"}
category GET /categories/:id(.:format) {:controller=>"categories", :action=>"show"}
PUT /categories/:id(.:format) {:controller=>"categories", :action=>"update"}
DELETE /categories/:id(.:format) {:controller=>"categories", :action=>"destroy"}
cities GET /cities(.:format) {:controller=>"cities", :action=>"index"}
POST /cities(.:format) {:controller=>"cities", :action=>"create"}
new_city GET /cities/new(.:format) {:controller=>"cities", :action=>"new"}
edit_city GET /cities/:id/edit(.:format) {:controller=>"cities", :action=>"edit"}
city GET /cities/:id(.:format) {:controller=>"cities", :action=>"show"}
PUT /cities/:id(.:format) {:controller=>"cities", :action=>"update"}
DELETE /cities/:id(.:format) {:controller=>"cities", :action=>"destroy"}
users GET /users(.:format) {:controller=>"users", :action=>"index"}
POST /users(.:format) {:controller=>"users", :action=>"create"}
new_user GET /users/new(.:format) {:controller=>"users", :action=>"new"}
edit_user GET /users/:id/edit(.:format) {:controller=>"users", :action=>"edit"}
user GET /users/:id(.:format) {:controller=>"users", :action=>"show"}
PUT /users/:id(.:format) {:controller=>"users", :action=>"update"}
DELETE /users/:id(.:format) {:controller=>"users", :action=>"destroy"}
subcategories GET /subcategories(.:format) {:controller=>"subcategories", :action=>"index"}
POST /subcategories(.:format) {:controller=>"subcategories", :action=>"create"}
new_subcategory GET /subcategories/new(.:format) {:controller=>"subcategories", :action=>"new"}
edit_subcategory GET /subcategories/:id/edit(.:format) {:controller=>"subcategories", :action=>"edit"}
subcategory GET /subcategories/:id(.:format) {:controller=>"subcategories", :action=>"show"}
PUT /subcategories/:id(.:format) {:controller=>"subcategories", :action=>"update"}
DELETE /subcategories/:id(.:format) {:controller=>"subcategories", :action=>"destroy"}
classifieds GET /classifieds(.:format) {:controller=>"classifieds", :action=>"index"}
POST /classifieds(.:format) {:controller=>"classifieds", :action=>"create"}
new_classified GET /classifieds/new(.:format) {:controller=>"classifieds", :action=>"new"}
edit_classified GET /classifieds/:id/edit(.:format) {:controller=>"classifieds", :action=>"edit"}
classified GET /classifieds/:id(.:format) {:controller=>"classifieds", :action=>"show"}
PUT /classifieds/:id(.:format) {:controller=>"classifieds", :action=>"update"}
DELETE /classifieds/:id(.:format) {:controller=>"classifieds", :action=>"destroy"}
POST /user(.:format) {:controller=>"users", :action=>"create"}
GET /user/new(.:format) {:controller=>"users", :action=>"new"}
GET /user/edit(.:format) {:controller=>"users", :action=>"edit"}
GET /user(.:format) {:controller=>"users", :action=>"show"}
PUT /user(.:format) {:controller=>"users", :action=>"update"}
DELETE /user(.:format) {:controller=>"users", :action=>"destroy"}
root /(.:format) {:controller=>"main", :action=>"index"}
/:controller(/:action(/:id(.:format)))
/simple_captcha/:action(.:format) {:controller=>"simple_captcha"}
logout /logout(.:format) {:controller=>"users", :action=>"destroy"}
login /login(.:format) {:controller=>"users", :action=>"show"}
adminsearch /adminsearch(.:format) {:controller=>"classifieds", :action=>"adminsearch"}
mainsearch /mainsearch(.:format) {:controller=>"main", :action=>"mainsearch"}
/:permalink_1/categorysearch(.:format) {:controller=>"main", :action=>"categorysearch"}
contactadvertiser /contactadvertiser(.:format) {:controller=>"main", :action=>"contactadvertiser"}
/:permalink_1(.:format) {:controller=>"main", :action=>"city"}
edit /edit(.:format) {:controller=>"cities", :action=>"edit"}
/activate/:activation_code(.:format) {:controller=>"main", :action=>"activate"}
/edit/:activation_code(.:format) {:controller=>"classifieds", :action=>"edit"}
/update/:activation_code(.:format) {:controller=>"classifieds", :action=>"update"}
/delete/:activation_code(.:format) {:controller=>"classifieds", :action=>"destroy"} classifieds_multidelete /classifieds/multidelete(.:format) {:controller=>"classifieds", :action=>"delete_multiple"}
/:permalink_1/:permalink_2(.:format) {:controller=>"main", :action=>"category"}
/:permalink_1/:permalink_2/:permalink_3(.:format) {:controller=>"classifieds", :action=>"show"}
simple_captcha /simple_captcha/:id(.:format) {:controller=>"simple_captcha", :action=>"show"}

You want to do:
<%= link_to "Edit", edit_classified_path(:activation_code => classified)%>
or edit your routes.rb to:
match '/edit/:id', :controller => 'classifieds', :action => 'edit'

Your routes are very redundant and contradictory. First, try getting rid of the catch-all route:
match ':controller(/:action(/:id(.:format)))'
as it should not be used if you're using RESTful routes. If that doesn't help, let me know and I'll update my answer accordingly.
Further, all of your match routes are incorrect. They should follow the pattern:
match '/my_controller/:id' => 'my_controller#action'

Related

no route matches controller (Rails 3)

I'm pretty new to RoR, please help me identify where I am wrong
I get the following error
Routing Error
No route matches {:controller=>"groups"}
Try running rake routes for more information on available routes
when trying to render the following view
<li><%= link_to 'My groups', user_groups_path %></li>
<li><%= link_to 'New group', new_user_group_path %></li>
and here is 'routes.rb' and rake routes output
devise_for :users
resources :users do |user|
resources :groups do |group|
resources :people do |person|
end
end
end
new_user_session GET /users/sign_in(.:format) devise/sessions#new
user_session POST /users/sign_in(.:format) devise/sessions#create
destroy_user_session GET /users/sign_out(.:format) devise/sessions#destroy
user_password POST /users/password(.:format) devise/passwords#create
new_user_password GET /users/password/new(.:format) devise/passwords#new
edit_user_password GET /users/password/edit(.:format) devise/passwords#edit
PUT /users/password(.:format) devise/passwords#update
cancel_user_registration GET /users/cancel(.:format) devise/registrations#cancel
user_registration POST /users(.:format) devise/registrations#create
new_user_registration GET /users/sign_up(.:format) devise/registrations#new
edit_user_registration GET /users/edit(.:format) devise/registrations#edit
PUT /users(.:format) devise/registrations#update
DELETE /users(.:format) devise/registrations#destroy
user_group_people GET /users/:user_id/groups/:group_id/people(.:format) people#index
POST /users/:user_id/groups/:group_id/people(.:format) people#create
new_user_group_person GET /users/:user_id/groups/:group_id/people/new(.:format) people#new
edit_user_group_person GET /users/:user_id/groups/:group_id/people/:id/edit(.:format) people#edit
user_group_person GET /users/:user_id/groups/:group_id/people/:id(.:format) people#show
PUT /users/:user_id/groups/:group_id/people/:id(.:format) people#update
DELETE /users/:user_id/groups/:group_id/people/:id(.:format) people#destroy
groups GET /users/:user_id/groups(.:format) groups#index
POST /users/:user_id/groups(.:format) groups#create
new_user_group GET /users/:user_id/groups/new(.:format) groups#new
edit_user_group GET /users/:user_id/groups/:id/edit(.:format) groups#edit
user_group GET /users/:user_id/groups/:id(.:format) groups#show
PUT /users/:user_id/groups/:id(.:format) groups#update
DELETE /users/:user_id/groups/:id(.:format) groups#destroy
users GET /users(.:format) users#index
POST /users(.:format) users#create
new_user GET /users/new(.:format) users#new
edit_user GET /users/:id/edit(.:format) users#edit
user GET /users/:id(.:format) users#show
PUT /users/:id(.:format) users#update
DELETE /users/:id(.:format) users#destroy
here is 'model.rb'
class User < ActiveRecord::Base
has_many :groups
class Group < ActiveRecord::Base
belongs_to :user
has_many :people
please help me figure out how to fix the problem
many thanks.
UPD
here is solution, it works
I made all changes suggested by #Abibullah and two changes in controllers
view:
<li><%= link_to 'My groups', user_groups_path(current_user) %></li>
<li><%= link_to 'New group', new_user_group_path(current_user) %></li>
routes.rb
resources :users do |user|
resources :groups do |group|
resources :people
end
end
devise_for :users
GroupsController.rb:
def index
#user = current_user
#user.groups = Group.all
was:
def index
#user = current_user
#groups = Group.all
end
UsersController.rb
class Devise::UsersController < DeviseController
def show
end
end
To Create a nested Group Inside User, U need to pass the user_id inside which U are Creating the Group.
For Ex: If I have user1
Then I will use the routes as this:
link_to 'My groups', user_groups_path(user1)
OR
link_to 'My groups', user_groups_path(user1.id)
AND
link_to 'My Group', new_user_group_path(user1)
OR
link_to 'My Group', new_user_group_path(user1.id)
This is to tell that, To which User you are creating the Group.
If U want to access any specific Group, say for ex: grp1
then My url will be
link_to 'My Group', user_group_path(user1, grp1)
THis is a good refrence for routing.
http://guides.rubyonrails.org/routing.html
I think it's obvious. You've got a typo in your
<li><%= link_to 'My groups', user_groups_path %></li>
link. The path should be user_group_path (without the 's') as shown in your rake routes output, instead of the one you've written in your link.

link_to update a Devise user, method => put

I'm trying to update a single databasefield of my current_user (devise).
I want to do this just with the link_to helper:
<%= link_to "Grid", edit_user_registration_path(current_user, :project_view => "grid"), :method => :put %>
But I can't get it to work since the result it allways an error:
Routing Error
No route matches [PUT] "/users/edit.1"
My Routes for Devise:
new_user_session GET /users/sign_in(.:format) devise/sessions#new
user_session POST /users/sign_in(.:format) devise/sessions#create
destroy_user_session DELETE /users/sign_out(.:format) devise/sessions#destroy
user_password POST /users/password(.:format) devise/passwords#create
new_user_password GET /users/password/new(.:format) devise/passwords#new
edit_user_password GET /users/password/edit(.:format) devise/passwords#edit
PUT /users/password(.:format) devise/passwords#update
cancel_user_registration GET /users/cancel(.:format) devise/registrations#cancel
user_registration POST /users(.:format) devise/registrations#create
new_user_registration GET /users/sign_up(.:format) devise/registrations#new
edit_user_registration GET /users/edit(.:format) devise/registrations#edit
PUT /users(.:format) devise/registrations#update
DELETE /users(.:format) devise/registrations#destroy
What's wrong with the routing? I'm using devise without any custom modifications.
Thanks!
Wrong path helper:
$ rake routes
new_user_registration GET ... registrations#new
cancel_user_registration GET ... registrations#cancel
user_registration POST ... registrations#create
edit_user_registration GET ... registrations#edit
users PUT ... registrations#update # You want this one
DELETE ... registrations#destroy
Result:
<%= link_to "Grid", users_path(:user => {:project_view => 'grid'}), :method => :put, :confirm => "Are you sure?" %>
Update for your specific routes:
<%= link_to "Grid", registration_path(resource_name, :user => {:project_view => 'grid'}), :method => :put, :confirm => "Are you sure?" %>

SSL integration with Devise How-To, Not Authenticating

I am using SSL Requirement to achieve the proper rediects with Devise. I am using custom devise controllers so I am able to drop in the ssl_required in them.
Gemfile
gem 'bartt-ssl_requirement', '1.2.7', :require => 'ssl_requirement'
application_controller.rb
class ApplicationController < ActionController::Base
protect_from_forgery
include ::SslRequirement
I also customized the hostname for SSLRequirement
production.rb
config.after_initialize do
SslRequirement.ssl_host = 'secure.website.com'
end
Setting up Custom Devise Controllers is as simple as making a new controller file and having the appropriate naming: (e.g. Session Controller). Be sure to generate the views and move them into the appropriate folder so your custom controller can use them.
session_controller.rb
class SessionsController < Devise::SessionsController
ssl_exceptions
def new
super
end
...
All this is working for met yet once I enable ssl_required (or ssl_exceptions), Devise is no longer able to authenticate. It redirects me to index or keeps me on the login page.
I made sure to go into session_store.rb and update my cookie_store to include
session_store.rb
App::Application.config.session_store :cookie_store, :key => '_app_session', :httponly => true, :secure => true, :domain => '.website.com'
for me, adding :domain => :all was not solving the problem either
Went into my devise.rb file and included:
devise.rb
config.cookie_options = { :secure => true }
still no success... even wrote all custom routes skipping over Devise defaults so they would include the https protocol and the secure subdomain host, and skip default devise routes to get rid of duplicate paths... I'm running out of options at this point:
routes.rb
constraints :protocol => "https", :host => "secure.website.com" do
devise_for :users, :controllers => { :sessions => 'sessions', :registrations => 'registrations', :passwords => 'passwords', :confirmations => 'confirmations', :unlocks => 'unlocks' }, :skip => [:sessions, :passwords, :registrations]
devise_scope :user do
#sessions
get "/users/sign_in" => "sessions#new", :as => nil
get "/users/sign_in" => "sessions#new", :as => :new_user_session
get "/users/sign_in" => "sessions#new", :as => :users_sign_in
get "/users/sign_out" => "sessions#destroy", :as => :destroy_user_session
get "/users/sign_out" => "sessions#destroy", :as => :users_sign_out
post "/users/sign_in" => "sessions#create", :as => :user_session
post "/users/sign_in" => "sessions#new", :as => nil
#registrations
get "/users/sign_up" => "registrations#new", :as => :users_sign_up
get "/users/sign_up" => "registrations#new", :as => :new_user_registration
get "/users/edit" => "registrations#edit", :as => :users_edit
get "/users/edit" => "registrations#edit", :as => :edit_user_registrations
get "/users/cancel" => "registrations#cancel", :as => :cancel_user_registration
post "/users/" => "registrations#create", :as => :user_registration
put "/users" => "registrations#update"
delete "/users" => "registrations#destroy"
#passwords
get "/users/password/new" => "passwords#new", :as => :users_password_new
get "/users/password/new" => "passwords#new", :as => :new_user_password
get "/users/password/edit" => "passwords#edit", :as => :edit_user_password
post "/users/password" => "passwords#create"
put "/users/password" => "passwords#update"
end
devise_for :admins, :controllers => { :sessions => 'sessions', :registrations => 'registrations', :passwords => 'passwords', :confirmations => 'confirmations', :unlocks => 'unlocks' }, :skip => [:sessions, :unlocks]
as :admin do
#sessions
get "/admins/sign_in" => "sessions#new"
get "/admins/sign_in" => "sessions#new", :as => :admins_sign_in
get "/admins/sign_in" => "sessions#new", :as => :new_admin_session
get "/admins/sign_out" => "sessions#destroy", :as => :destroy_admin_session
get "/admins/sign_out" => "sessions#destroy", :as => :admins_sign_out
post "/admins/sign_in" => "sessions#new"
post "/admins/sign_in" => "sessions#new", :as => :admin_session
#unlocks
get "/admins/unlock" => "unlocks#show"
get "/admins/unlock/new" => "unlocks#new", :as => :admins_unlock_new
get "/admins/unlock/new" => "unlocks#new", :as => :new_admin_unlock
post "/admins/unlock" => "unlocks#create", :as => :admin_unlock
end
end
rake routes
GET /users/sign_in(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"new"}
new_user_session GET /users/sign_in(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"new"}
users_sign_in GET /users/sign_in(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"new"}
destroy_user_session GET /users/sign_out(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"destroy"}
users_sign_out GET /users/sign_out(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"destroy"}
user_session POST /users/sign_in(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"create"}
POST /users/sign_in(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"new"}
users_sign_up GET /users/sign_up(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"registrations", :action=>"new"}
new_user_registration GET /users/sign_up(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"registrations", :action=>"new"}
users_edit GET /users/edit(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"registrations", :action=>"edit"}
edit_user_registrations GET /users/edit(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"registrations", :action=>"edit"}
cancel_user_registration GET /users/cancel(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"registrations", :action=>"cancel"}
user_registration POST /users(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"registrations", :action=>"create"}
users PUT /users(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"registrations", :action=>"update"}
DELETE /users(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"registrations", :action=>"destroy"}
users_password_new GET /users/password/new(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"passwords", :action=>"new"}
new_user_password GET /users/password/new(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"passwords", :action=>"new"}
edit_user_password GET /users/password/edit(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"passwords", :action=>"edit"}
users_password POST /users/password(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"passwords", :action=>"create"}
PUT /users/password(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"passwords", :action=>"update"}
admins_sign_in GET /admins/sign_in(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"new"}
admins_sign_in GET /admins/sign_in(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"new"}
new_admin_session GET /admins/sign_in(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"new"}
destroy_admin_session GET /admins/sign_out(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"destroy"}
admins_sign_out GET /admins/sign_out(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"destroy"}
POST /admins/sign_in(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"new"}
admin_session POST /admins/sign_in(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"sessions", :action=>"new"}
admins_unlock GET /admins/unlock(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"unlocks", :action=>"show"}
admins_unlock_new GET /admins/unlock/new(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"unlocks", :action=>"new"}
new_admin_unlock GET /admins/unlock/new(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"unlocks", :action=>"new"}
admin_unlock POST /admins/unlock(.:format) {:protocol=>"https", :host=>"secure.website.com", :controller=>"unlocks", :action=>"create"}
I am almost positive it has to do with my cookies, anyone have 2 cents?
I can post more app code or console code if need be. I hope this has been a help to anyone setting up customized Devise and anyone incorporating SSL into their rails3 app using Devise and SSLRequirement.
Hopefully we can get a complete write-up for a solid example for everyone. Thanks and let me know if you have any questions about how I set up custom devise controllers/views/etc...

Rails RoutingError: No route matches {:controller=>"sessions", :action=>"destroy"}

Yet when run rake:routes it appears to be there:
users GET /users(.:format) {:action=>"index", :controller=>"users"}
POST /users(.:format) {:action=>"create", :controller=>"users"}
new_user GET /users/new(.:format) {:action=>"new", :controller=>"users"}
edit_user GET /users/:id/edit(.:format) {:action=>"edit", :controller=>"users"}
user GET /users/:id(.:format) {:action=>"show", :controller=>"users"}
PUT /users/:id(.:format) {:action=>"update", :controller=>"users"}
DELETE /users/:id(.:format) {:action=>"destroy", :controller=>"users"}
sessions POST /sessions(.:format) {:action=>"create", :controller=>"sessions"}
new_session GET /sessions/new(.:format) {:action=>"new", :controller=>"sessions"}
session DELETE /sessions/:id(.:format) {:action=>"destroy", :controller=>"sessions"}
signup /signup(.:format) {:controller=>"users", :action=>"new"}
contact /contact(.:format) {:controller=>"pages", :action=>"contact"}
about /about(.:format) {:controller=>"pages", :action=>"about"}
help /help(.:format) {:controller=>"pages", :action=>"help"}
root /(.:format) {:controller=>"pages", :action=>"home"}
Here are the routes from routes.rb:
resources :users
resources :sessions, :only => [:new, :create, :destroy]
match '/signup', to: 'users#new'
match '/contact', to: 'pages#contact'
match '/about', to: 'pages#about'
match '/help', to: 'pages#help'
It's possible that you are not passing the :id param in your route, which is why the route is not matched, since :id is required:
session DELETE /sessions/:id(.:format) {:action=>"destroy", :controller=>"sessions"}
Note: The parentheses around the :format param mean that it is optional.
I got the same error as well.But the reason is the little mistake that in the view page I write
<%= form_for(:session,url:session_path) do |f| %>
which I less the last 's' of 'sessions'.
This looks like an error I was running into when running through http://ruby.railstutorial.org/, and it turned out that I had left a few things out of routes.rb. The addition of the resource route is accompanied by the following two additional routes:
match '/signin', :to => 'sessions#new'
match '/signout', :to => 'sessions#destroy'
It's hard to see because the first route in that group is already there, so I had just glossed over the group (several times) as already being there.
resources controller adds map to method
{:action=>"method", :controller=>"controller"}
when in your case the rails seemed to ask for explicitly the map as
{:controller=>“controller”, :action=>“method”}
The :controller is before :action
This also answered Noach's question why match '/signout', :to => 'sessions#destroy' has to exist, if you rake:routes you will see it added
{:controller=>“sessions”, :action=>“destroy”} while there is already a
{:action=>“destroy”, :controller=>“sessions”} added by resources sessions

what's the path to destroy registration with devise

I'm trying to add a link so the user can destroy his/her own account. I'm using the built-in registration class.
In my view I have <%= link_to 'Destroy', current_user, :confirm => 'Are you sure you want to destroy your account?', :method => :delete %> pointing to localhost:3000/users/4 by example
First of all, is that the correct link to use?
Secondly, how to redirect to root path because presently it looks like it tries to redirect to user with id 4 (and it fails because it is protected).
Rake routes gives DELETE /users(.:format) {:action=>"destroy", :controller=>"devise/registrations"}
Thanks in advance.
Try
<%= link_to 'Destroy', user_registration_path, :confirm => 'Are you sure you want to destroy your account?', :method => :delete %>
It's because of devise treat registration as Singular Resource.
Besides, run rake routes and you can see details about registration routing:
user_registration POST /users(.:format) {:action=>"create", :controller=>"devise/registrations"}
new_user_registration GET /users/sign_up(.:format) {:action=>"new", :controller=>"devise/registrations"}
edit_user_registration GET /users/edit(.:format) {:action=>"edit", :controller=>"devise/registrations"}
user_registration PUT /users(.:format) {:action=>"update", :controller=>"devise/registrations"}
user_registration DELETE /users(.:format) {:action=>"destroy", :controller=>"devise/registrations"}
It means:
user_registration_path is a helper method that returns /users(.format)
Perform DELETE request on /users(.format) will delete the registration