Jason Newport
2010-Apr-02 14:07 UTC
App_Controller and partial issues with has_many through
I have a User model, a Post model, and an Interest model:
User has_many posts through interests
User has_many interests, dependent destroy
Post has_many users through interests
has_many interests, dependent destroy
Post has_many interests
Interest belongs to Post
Interest belongs to User
Application_Controller is as follows:
class ApplicationController < ActionController::Base
before_filter :login_from_cookie
before_filter :find_user_interests
helper :all # include all helpers, all the time
session :session_key => ''_blah_session''
include AuthenticatedSystem
def find_user_interests
@user_interests = current_user ? current_user.interests : []
true
end
end
Application.html.erb has as follows:
<%= render :partial => "users/interests", :object =>
@user_interests %>
_interests.html.erb partial is as follows:
ul
<% unless current_user.nil? then -%>
<% @user_interests.each do |interest| -%>
li<%= interest.post.title %>/li
<% end %>
<% end -%>
/ul
Given all this when I at localhost:3000/posts/1 my partial shows up
fine, but when in localhost:3000/posts I get an error undefined method
''title'' for nil:NilClass thus an error in the line
li<%interest.post.title %>/li shown above in the _interests.html.erb
partial.
What the heck would be the issue?
Also what is weird, if I take out the code in the partial that dislays
the title, so to get around this error, I have another issue. I have a
title in the partial that is set like "You have @user_interests.length
interests" and when I am on the posts page and say the posts page has 10
posts my title reads like "You have 10 interests" so its counting all
posts as an interest, even if the user hasn''t selected the post as an
interest. And when I go to one specific Posts page, on that single Post
page, the above referenced title reads "You have 1 interests" so its
seems to be counting the number of posts on the specific pages (index or
show) and totaling those up as a users interests. And if for one user I
add two interests and view the single post page then the title will read
"You have 3 interests", thus counts the two interests I really am
interested in plus the one for the Post page I am even though I have yet
to click/select it as an interest.
TIA
--
Posted via http://www.ruby-forum.com/.
--
You received this message because you are subscribed to the Google Groups
"Ruby on Rails: Talk" group.
To post to this group, send email to
rubyonrails-talk-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org
To unsubscribe from this group, send email to
rubyonrails-talk+unsubscribe-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org
For more options, visit this group at
http://groups.google.com/group/rubyonrails-talk?hl=en.
Colin Law
2010-Apr-02 14:58 UTC
Re: App_Controller and partial issues with has_many through
On 2 April 2010 15:07, Jason Newport <lists-fsXkhYbjdPsEEoCn2XhGlw@public.gmane.org> wrote:> I have a User model, a Post model, and an Interest model: > User has_many posts through interests > User has_many interests, dependent destroy > Post has_many users through interests > has_many interests, dependent destroy > Post has_many interests > Interest belongs to Post > Interest belongs to User > > Application_Controller is as follows: > class ApplicationController < ActionController::Base > before_filter :login_from_cookie > before_filter :find_user_interests > helper :all # include all helpers, all the time > session :session_key => ''_blah_session'' > > include AuthenticatedSystem > > def find_user_interests > @user_interests = current_user ? current_user.interests : [] > true > end > > end > > Application.html.erb has as follows: > <%= render :partial => "users/interests", :object => @user_interests %> > > _interests.html.erb partial is as follows: > > ul > <% unless current_user.nil? then -%> > <% @user_interests.each do |interest| -%> > li<%= interest.post.title %>/li > <% end %> > <% end -%> > /ul > > Given all this when I at localhost:3000/posts/1 my partial shows up > fine, but when in localhost:3000/posts I get an error undefined method > ''title'' for nil:NilClass thus an error in the line li<%> interest.post.title %>/li shown above in the _interests.html.erb > partial. > > What the heck would be the issue? > > Also what is weird, if I take out the code in the partial that dislays > the title, so to get around this error, I have another issue. I have a > title in the partial that is set like "You have @user_interests.length > interests" and when I am on the posts page and say the posts page has 10 > posts my title reads like "You have 10 interests" so its counting all > posts as an interest, even if the user hasn''t selected the post as an > interest. And when I go to one specific Posts page, on that single Post > page, the above referenced title reads "You have 1 interests" so its > seems to be counting the number of posts on the specific pages (index or > show) and totaling those up as a users interests. And if for one user I > add two interests and view the single post page then the title will read > "You have 3 interests", thus counts the two interests I really am > interested in plus the one for the Post page I am even though I have yet > to click/select it as an interest.I would suggest installing ruby-debug, then you can break into the controller or the view and inspect the variables and work out what is going wrong. See the rails guide on debugging at http://guides.rubyonrails.org/ Colin -- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group. To post to this group, send email to rubyonrails-talk-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org To unsubscribe from this group, send email to rubyonrails-talk+unsubscribe@googlegroups.com. For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en.
Jason Newport
2010-Apr-03 02:26 UTC
Re: App_Controller and partial issues with has_many through
When inspecting it I get [#,#,#,#] and my title reads "Your Interests (4)" and the print out is # # # # What is # all about? Is that an object filled with objects? Colin Law wrote:> On 2 April 2010 15:07, Jason Newport <lists-fsXkhYbjdPsEEoCn2XhGlw@public.gmane.org> wrote: >> class ApplicationController < ActionController::Base >> �end >> � �<% @user_interests.each do |interest| -%> >> >> seems to be counting the number of posts on the specific pages (index or >> show) and totaling those up as a users interests. �And if for one user I >> add two interests and view the single post page then the title will read >> "You have 3 interests", thus counts the two interests I really am >> interested in plus the one for the Post page I am even though I have yet >> to click/select it as an interest. > > I would suggest installing ruby-debug, then you can break into the > controller or the view and inspect the variables and work out what is > going wrong. > > See the rails guide on debugging at http://guides.rubyonrails.org/ > > Colin-- Posted via http://www.ruby-forum.com/. -- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group. To post to this group, send email to rubyonrails-talk-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org To unsubscribe from this group, send email to rubyonrails-talk+unsubscribe@googlegroups.com. For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en.
Jason Newport
2010-Apr-03 03:16 UTC
Re: App_Controller and partial issues with has_many through
So I put this in my controller:
logger.debug "Person attributes hash: #{@user_interests.inspect}"
And got this:
Person attributes hash: [#<Interest id: 6, user_id: 5, post_id: 1,
created_at: "2010-04-01 23:52:53", updated_at: "2010-04-01
23:52:53">,
#<Interest id: 7, user_id: 5, post_id: 2, created_at: "2010-04-01
23:53:08", updated_at: "2010-04-01 23:53:08">]
Shouldn''t it be the interest.post info for each interest, not just the
model attributes for the interest table?
--
Posted via http://www.ruby-forum.com/.
--
You received this message because you are subscribed to the Google Groups
"Ruby on Rails: Talk" group.
To post to this group, send email to
rubyonrails-talk-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org
To unsubscribe from this group, send email to
rubyonrails-talk+unsubscribe-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org
For more options, visit this group at
http://groups.google.com/group/rubyonrails-talk?hl=en.
Colin Law
2010-Apr-03 07:37 UTC
Re: Re: App_Controller and partial issues with has_many through
On 3 April 2010 04:16, Jason Newport <lists-fsXkhYbjdPsEEoCn2XhGlw@public.gmane.org> wrote:> So I put this in my controller: > logger.debug "Person attributes hash: #{@user_interests.inspect}" > > > And got this: > Person attributes hash: [#<Interest id: 6, user_id: 5, post_id: 1, > created_at: "2010-04-01 23:52:53", updated_at: "2010-04-01 23:52:53">, > #<Interest id: 7, user_id: 5, post_id: 2, created_at: "2010-04-01 > 23:53:08", updated_at: "2010-04-01 23:53:08">] > > Shouldn''t it be the interest.post info for each interest, not just the > model attributes for the interest table?Inspect will only show you the array of Interest objects, which is what you have in @user_interests, it does not dive down into the relationships. Colin> -- > Posted via http://www.ruby-forum.com/. > > -- > You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group. > To post to this group, send email to rubyonrails-talk-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org > To unsubscribe from this group, send email to rubyonrails-talk+unsubscribe-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org > For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en. > >-- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group. To post to this group, send email to rubyonrails-talk-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org To unsubscribe from this group, send email to rubyonrails-talk+unsubscribe-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en.
Colin Law
2010-Apr-03 07:40 UTC
Re: Re: App_Controller and partial issues with has_many through
On 3 April 2010 03:26, Jason Newport <lists-fsXkhYbjdPsEEoCn2XhGlw@public.gmane.org> wrote:> When inspecting it I get [#,#,#,#] and my title reads "Your Interests > (4)" and the print out is > # > # > # > # > > What is # all about? Is that an object filled with objects?Inspecting what? What happens if in the debugger you just type the variable name my_variable_name Colin> > > > > Colin Law wrote: >> On 2 April 2010 15:07, Jason Newport <lists-fsXkhYbjdPsEEoCn2XhGlw@public.gmane.org> wrote: >>> class ApplicationController < ActionController::Base >>> �end >>> � �<% @user_interests.each do |interest| -%> >>> >>> seems to be counting the number of posts on the specific pages (index or >>> show) and totaling those up as a users interests. �And if for one user I >>> add two interests and view the single post page then the title will read >>> "You have 3 interests", thus counts the two interests I really am >>> interested in plus the one for the Post page I am even though I have yet >>> to click/select it as an interest. >> >> I would suggest installing ruby-debug, then you can break into the >> controller or the view and inspect the variables and work out what is >> going wrong. >> >> See the rails guide on debugging at http://guides.rubyonrails.org/ >> >> Colin > > -- > Posted via http://www.ruby-forum.com/. > > -- > You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group. > To post to this group, send email to rubyonrails-talk-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org > To unsubscribe from this group, send email to rubyonrails-talk+unsubscribe@googlegroups.com. > For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en. > >-- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group. To post to this group, send email to rubyonrails-talk-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org To unsubscribe from this group, send email to rubyonrails-talk+unsubscribe@googlegroups.com. For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en.
Jason Newport
2010-Apr-03 13:13 UTC
Re: Re: App_Controller and partial issues with has_many through
So I figured out the issue, but now I am wondering if setting this
variable here isn''t a good idea, but rather doing it in a helper or
somewhere else?
I am using AuthenticatedSystem and it has a function current_user which
of cource gets the current user. So in my Application controller where
I am setting my @user_interests variable it some how doesn''t have
access
to that function I guess. So as I created this function in the
ApplicationController and it all works now.
def cur_user
User.find(session[:user_id]) if session[:user_id]
end
So now my ApplicationController code looks like this:
class ApplicationController < ActionController::Base
include AuthenticatedSystem
helper :all # include all helpers, all the time
session :session_key => ''_inchs_session''
# See ActionController::RequestForgeryProtection for details
# Uncomment the :secret if you''re not using the cookie session store
protect_from_forgery # :secret =>
''eefa7eded747690e8efdb2044a729b4f''
before_filter :login_from_cookie
before_filter :find_user_interests
protected
def find_user_interests
@user_interests = cur_user ? cur_user.interests : []
logger.debug "Person attributes hash: #{current_user.inspect}"
end
def cur_user
User.find(session[:user_id]) if session[:user_id]
end
end
--
Posted via http://www.ruby-forum.com/.
--
You received this message because you are subscribed to the Google Groups
"Ruby on Rails: Talk" group.
To post to this group, send email to
rubyonrails-talk-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org
To unsubscribe from this group, send email to
rubyonrails-talk+unsubscribe-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org
For more options, visit this group at
http://groups.google.com/group/rubyonrails-talk?hl=en.