I have a User model and a Storefront model.
For some reason, when I try to go to /storefronts/new I get this error:
Routing Error
No route matches {:action=>”edit”, :controller=>”storefronts”,
:id=># Storefront id: nil, name: nil, user_id: 4, created_at: nil,
updated_at: nil, description: nil, location: nil>}
Been at it for 3 hours trying to figure this out. It was working yesterday..
Why does it say :action=>”edit” when its the ‘new’ action?
Here’s my code:
class Storefront < ActiveRecord::Base
attr_accessible :name, :location, :description
belongs_to :user
end
class User < ActiveRecord::Base
attr_accessible :name, :email, :password, :password_confirmation
has_secure_password
has_one :storefront
end
class StorefrontsController < ApplicationController
before_filter :check_auth, only: [:new, :edit, :update]
def index
@storefronts = Storefront.all
end
def new
@storefront = current_user.build_storefront
end
def create
@storefront = current_user.build_storefront(params[:storefront])
if @storefront.save
redirect_to edit_storefront_path(@storefront)
else
render 'new'
end
end
def show
@storefront = Storefront.find(params[:id])
end
def edit
@storefront = Storefront.find(params[:id])
end
def update
@storefront = Storefront.find(params[:id])
if @storefront.update_attributes(params[:storefront])
redirect_to @storefront
else
render 'edit'
end
end
end
Pbf::Application.routes.draw do
resources :sessions, :only => [:new, :create, :destroy]
resources :users
resources :storefronts
root :to => 'storefronts#index'
match '/signup', to: 'users#new'
match '/login', to: 'sessions#new'
match '/logout', to: 'sessions#destroy'
end
Link I’m using (Here’s the issue):
<% if current_user.storefront %>
<%= link_to "Manage Storefront", edit_storefront_path(current_user.storefront) %>
<% else %>
<%= link_to "Open Storefront!", openstore_path %>
<% end %>
Thanks in advance!
EDIT:
My rake routes
sessions POST /sessions(.:format) sessions#create new_session GET /sessions/new(.:format) sessions#new session DELETE /sessions/:id(.:format) sessions#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 storefronts GET /storefronts(.:format) storefronts#index POST /storefronts(.:format) storefronts#create new_storefront GET /storefronts/new(.:format) storefronts#new edit_storefront GET /storefronts/:id/edit(.:format) storefronts#edit storefront GET /storefronts/:id(.:format) storefronts#show PUT /storefronts/:id(.:format) storefronts#update DELETE /storefronts/:id(.:format) storefronts#destroy
It looks to me like you have an error in your view.
app/views/storefronts/new.html.erbis mistakenly referencingedit_storefront_pathwithout passingstorefront_idas a parameter. You probably wantstorefronts_path