Module: ActiveRecord::AttributeAssignment
- Extended by:
- ActiveSupport::Concern
- Included in:
- Base
- Defined in:
- activerecord/lib/active_record/attribute_assignment.rb
Defined Under Namespace
Classes: MultiparameterAttribute
Instance Method Summary collapse
-
#assign_attributes(new_attributes) ⇒ Object
(also: #attributes=)
Allows you to set all the attributes by passing in a hash of attributes with keys matching the attribute names (which again matches the column names).
Methods included from ActiveSupport::Concern
append_features, extended, included
Instance Method Details
#assign_attributes(new_attributes) ⇒ Object Also known as: attributes=
Allows you to set all the attributes by passing in a hash of attributes with keys matching the attribute names (which again matches the column names).
If the passed hash responds to permitted?
method and the return value of this method is false
an ActiveModel::ForbiddenAttributesError
exception is raised.
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 |
# File 'activerecord/lib/active_record/attribute_assignment.rb', line 14 def assign_attributes(new_attributes) if !new_attributes.respond_to?(:stringify_keys) raise ArgumentError, "When assigning attributes, you must pass a hash as an argument." end return if new_attributes.blank? attributes = new_attributes.stringify_keys multi_parameter_attributes = [] nested_parameter_attributes = [] attributes = sanitize_for_mass_assignment(attributes) attributes.each do |k, v| if k.include?("(") multi_parameter_attributes << [ k, v ] elsif v.is_a?(Hash) nested_parameter_attributes << [ k, v ] else _assign_attribute(k, v) end end assign_nested_parameter_attributes(nested_parameter_attributes) unless nested_parameter_attributes.empty? assign_multiparameter_attributes(multi_parameter_attributes) unless multi_parameter_attributes.empty? end |