Pregunta

class Job < ActiveRecord::Base    
has_many :employments, :dependent => :destroy
has_many :users, :through => :employments

class User < ActiveRecord::Base
has_many :employments 
has_many :jobs, :through => :employments

class Employment < ActiveRecord::Base
belongs_to :job
belongs_to :user  # Employment has an extra attribute of confirmed ( values are 1 or 0)

En mi opinión estoy tratando de actualizar los confirmados ficado de 0 a 1 el usuario hace clic.

<%= link_to "Confirm Job", :action => :confirmjob, :id => job.id %>

En mi Controlador de trabajo que tengo

def confirmjob
  @job = Job.find(params[:id])
  @job.employments.update_attributes(:confirmed, 1)
  flash[:notice] = "Job Confirmed"
  redirect_to :dashboard
end

Estoy seguro de que esto es un error, pero me parece estar adivinando cuando se trata de has_many: a través. ¿Cómo haría actualizar el campo confirmó en una tabla unida?

¿Fue útil?

Solución

Creo que un trabajo se asigna a un usuario por el empleo. Por lo tanto, la actualización de todos los empleos no es una buena idea, como sugiere Joel. Yo recomendaría este:

class Employment
  def self.confirm!(job)
    employment = Employment.find(:first, :conditions => { :job_id => job.id } )
    employment.update_attribute(:confirmed, true)
  end
end

desde su controlador

@job = Job.find(params[:id])
Employment.confirm!(@job)

Esto implica que un trabajo sólo puede ser tomada por un usuario.

Otros consejos

Este es un puñalada en ella (no probado):

def confirmjob
  @job = Job.find(params[:id])
  @jobs.employments.each do |e|
    e.update_attributes({:confirmed => 1})
  end
  flash[:notice] = "Job Confirmed"
  redirect_to :dashboard
end
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top