Just tried: params[:book][:instance_id] = current_user.instance_id @book = current_user.books.create(params[:book])
for some reason, instance_id is still not being inserted into the DB. In the dev log it shows as NULL. Any ideas? On Sep 7, 9:41 pm, nobosh <[email protected]> wrote: > Adam, > > Thanks for the answer, let me add a little color as to what I'm trying > to get working: > > I have the following models: Users (id, name, email, instance_id, > etc...) Instances (id, domain name) Books (id, name, user_id, > instance_id) > In Rails 3, When a new book is created, I need the user_id, and > instance_id to be populated based on the current_user. > Currently, user_id is being assigned when I create a new book but not > instance_id? > > class Instance < ActiveRecord::Base > has_many :users > has_many :books, :through => :users, :order => "created_at DESC" > end > > class User < ActiveRecord::Base > belongs_to :instance > has_many :books, :order => "created_at DESC" > end > > class Book < ActiveRecord::Base > belongs_to :user > has_one :instance, :through => :user > end > > Thoughts on this? I'm a newbie so I'd love to hear if I going down the > right track or not... > And I like your first suggestion assuming you like the models above: > > > params[:book][:instance_id] = current_user.instance_id > > @book = current_user.books.create(params[:book]) > > On Sep 7, 9:37 pm, Adam <[email protected]> wrote: > > > > > On Tue, Sep 7, 2010 at 11:02 PM, nobosh <[email protected]> wrote: > > > Hello, Rails newbie.... > > > > How can I go From: > > > > @book = current_user.books.build(params[:book]) > > > > TO: > > > > @book = current_user.books.create(params[:book], :instance => > > > current_user.instance_id) > > > > right now I get the following error "wrong number of arguments (2 for > > > 1)" > > > > Thanks > > > I'm assuming that 'instance_id' is an attribute of a Book. In that case, it > > needs to be part of the Hash you pass to #build or #create. You can do > > either:> params[:book][:instance_id] = current_user.instance_id > > > @book = current_user.books.create(params[:book]) > > or > > > @book = current_user.books.create(params[:book].merge(:instance_id => > > > current_user.instance_id)) > > Both assume that params[:book] is non-nil and is a Hash. I'd prefer the > > first - it's more readable. > > > Adam -- 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 [email protected]. To unsubscribe from this group, send email to [email protected]. For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en.

