如何在嵌套模型中将动态hstore密钥列入白名单

时间:2013-10-28 19:22:22

标签: ruby-on-rails-4 nested-attributes strong-parameters hstore

我有这些关系:

class Applicant < ActiveRecord::Base
  has_many :answers
  accepts_nested_attributes_for :answers
end

class Answer < ActiveRecord::Base
  belongs_to :applicant
end

答案模型有一个名为properties的hstore属性。属性哈希将具有动态密钥,因为它们是由用户在应用程序中创建的。

我似乎无法在申请人控制器中成功将这些动态密钥列入白名单。

这是我目前的(不成功)尝试。

def applicant_params
  params.require(:applicant).permit(:answers_attributes: [:question_id, :id]).tap do |whitelisted|
        whitelisted[:answers_attributes][:properties] = params[:applicant][:answers_attributes][:properties]
    end
end

感谢您的帮助。

1 个答案:

答案 0 :(得分:3)

UPD。尝试使用以下方法(在单独的文件中测试):

@params = ActionController::Parameters.new(
  applicant: {answers_attributes: { 
                "0" => {question_id: 10, id:  110, properties: {a: "b", c: "d"}}, 
                "1" => {question_id: 20, id:  120, properties: {m: "n", o: "p"}}
}})

def applicant_params
  #properties should be [:a, :c, :m, :o]
  properties = []
  @params[:applicant][:answers_attributes].values.each do |answer|
    properties |= answer[:properties].keys
  end
  @params.require(:applicant).permit(answers_attributes: 
                                       [:question_id, :id, properties: properties])
end

BTL。使用hstores时非常好article。以及使用hstore in Rails 4的一些常规事项。