Rails date_select и update_attributes - PullRequest
2 голосов
/ 21 марта 2012

Я собираюсь рвать на себе волосы, поэтому мне, должно быть, не хватает чего-то простого ...

У меня есть следующая форма (упрощенно):

<%= form_for(@public_call) do |f| %>
<div>Start: <%= f.date_select(:start_date,:start_year=>Time.now.year) -%></div>
<div>End: <%= f.date_select(:end_date,:start_year=>Time.now.year) -%></div>
<div>Deadline: <%= f.datetime_select(:submission_deadline,:start_year=>Time.now.year-1) -%></div>
<%- end -%>

Форма сообщенийк следующему методу (упрощенно):

def update
  begin
    @public_call = PublicCall.find(params[:id])
    @public_call.update_attributes!(params[:public_call])
  rescue
    ...
  end
end

Отправка формы приводит к следующему сообщению регистратора Rails (упрощенно):

Parameters:
  {"public_call"=>
    {"start_date(1i)"=>"2012",
     "start_date(2i)"=>"9",
     "start_date(3i)"=>"30",
     "end_date(1i)"=>"2012",
     "end_date(2i)"=>"10",
     "end_date(3i)"=>"3",
     "submission_deadline(1i)"=>"2012",
     "submission_deadline(2i)"=>"4",
     "submission_deadline(3i)"=>"27",
     "submission_deadline(4i)"=>"23",
     "submission_deadline(5i)"=>"59"}
  }

Вот проблема: Rails doesn 'Кажется, что параметры этих трех полей переводятся в объекты даты и даты и времени для базы данных, как это и должно быть.Запрос, сообщаемый регистратором Rails:

UPDATE `public_calls` SET `start_date`=NULL, `end_date`=NULL, `submission_deadline`=NULL, `updated_at`='2012-03-20 20:47:15' WHERE...

Любая идея, что дает?

Кстати, Rails 3.2.0 / Ruby 1.9.3.Ни один из моих атрибутов в модели public_calls не защищен.

Спасибо!

EDIT

Также пробовал использовать опцию :less_protection с update_attributes!но это тоже не работает.

EDIT # 2

Я попытался отладить, что происходит в модуле ActiveRecord AttributeAssignment следующим образом:

def assign_multiparameter_attributes(pairs)
  Rails.logger.info('ASSIGN_MULTIPARAMETER_ATTRIBUTES: '+pairs.inspect)
  execute_callstack_for_multiparameter_attributes(
    extract_callstack_for_multiparameter_attributes(pairs)
  )
end

def execute_callstack_for_multiparameter_attributes(callstack)
  errors = []
  Rails.logger.info('EXECUTE_CALLSTACK_FOR_MULTIPARAMETER_ATTRIBUTES: '+callstack.inspect)
  callstack.each do |name, values_with_empty_parameters|
    begin
      send(name + "=", read_value_from_parameter(name, values_with_empty_parameters))
    rescue => ex
      errors << AttributeAssignmentError.new("error on assignment #{values_with_empty_parameters.values.inspect} to #{name}", ex, name)
    end
  end
  unless errors.empty?
    raise MultiparameterAssignmentErrors.new(errors), "#{errors.size} error(s) on assignment of multiparameter attributes"
  end
end

def extract_callstack_for_multiparameter_attributes(pairs)
  Rails.logger.info('EXTRACT_CALLSTACK_FOR_MULTIPARAMETER_ATTRIBUTES: '+pairs.inspect)
  attributes = { }
  pairs.each do |pair|
    multiparameter_name, value = pair
    attribute_name = multiparameter_name.split("(").first
    attributes[attribute_name] = {} unless attributes.include?(attribute_name)
    parameter_value = value.empty? ? nil : type_cast_attribute_value(multiparameter_name, value)
    attributes[attribute_name][find_parameter_position(multiparameter_name)] ||= parameter_value
  end
  Rails.logger.info('EXTRACT_CALLSTACK_FOR_MULTIPARAMETER_ATTRIBUTES: '+attributes.inspect)
  attributes
end

И вот чтоЯ получаю:

ASSIGN_MULTIPARAMETER_ATTRIBUTES: [["start_date(1i)", "2012"], ["start_date(2i)", "9"], ["start_date(3i)", "30"], ["end_date(1i)", "2012"], ["end_date(2i)", "10"], ["end_date(3i)", "3"], ["submission_deadline(1i)", "2012"], ["submission_deadline(2i)", "4"], ["submission_deadline(3i)", "27"], ["submission_deadline(4i)", "23"], ["submission_deadline(5i)", "59"]]
EXTRACT_CALLSTACK_FOR_MULTIPARAMETER_ATTRIBUTES: [["start_date(1i)", "2012"], ["start_date(2i)", "9"], ["start_date(3i)", "30"], ["end_date(1i)", "2012"], ["end_date(2i)", "10"], ["end_date(3i)", "3"], ["submission_deadline(1i)", "2012"], ["submission_deadline(2i)", "4"], ["submission_deadline(3i)", "27"], ["submission_deadline(4i)", "23"], ["submission_deadline(5i)", "59"]]
EXTRACT_CALLSTACK_FOR_MULTIPARAMETER_ATTRIBUTES: {"start_date"=>{1=>2012, 2=>9, 3=>30}, "end_date"=>{1=>2012, 2=>10, 3=>3}, "submission_deadline"=>{1=>2012, 2=>4, 3=>27, 4=>23, 5=>59}}

Есть идеи, почему метод execute_callstack_for_multiparameter_attributes не вызывается?

1 Ответ

0 голосов
/ 12 августа 2012

Обновите вашу версию rails - у меня возникла та же проблема, переход с версии 3.2.0 на версию 3.2.8 решил ее за меня.

...