diff options
Diffstat (limited to 'activemodel/lib')
| -rw-r--r-- | activemodel/lib/active_model/serializers/json.rb | 19 | ||||
| -rw-r--r-- | activemodel/lib/active_model/validations/numericality.rb | 2 | 
2 files changed, 12 insertions, 9 deletions
| diff --git a/activemodel/lib/active_model/serializers/json.rb b/activemodel/lib/active_model/serializers/json.rb index 25e1541d66..f77fb98c32 100644 --- a/activemodel/lib/active_model/serializers/json.rb +++ b/activemodel/lib/active_model/serializers/json.rb @@ -26,13 +26,13 @@ module ActiveModel        #   user = User.find(1)        #   user.as_json        #   # => { "id" => 1, "name" => "Konata Izumi", "age" => 16, -      #   #     "created_at" => "2006/08/01", "awesome" => true} +      #   #     "created_at" => "2006-08-01T17:27:133.000Z", "awesome" => true}        #        #   ActiveRecord::Base.include_root_in_json = true        #        #   user.as_json        #   # => { "user" => { "id" => 1, "name" => "Konata Izumi", "age" => 16, -      #   #                  "created_at" => "2006/08/01", "awesome" => true } } +      #   #                  "created_at" => "2006-08-01T17:27:13.000Z", "awesome" => true } }        #        # This behavior can also be achieved by setting the <tt>:root</tt> option        # to +true+ as in: @@ -40,7 +40,7 @@ module ActiveModel        #   user = User.find(1)        #   user.as_json(root: true)        #   # => { "user" => { "id" => 1, "name" => "Konata Izumi", "age" => 16, -      #   #                  "created_at" => "2006/08/01", "awesome" => true } } +      #   #                  "created_at" => "2006-08-01T17:27:13.000Z", "awesome" => true } }        #        # Without any +options+, the returned Hash will include all the model's        # attributes. @@ -48,7 +48,7 @@ module ActiveModel        #   user = User.find(1)        #   user.as_json        #   # => { "id" => 1, "name" => "Konata Izumi", "age" => 16, -      #   #      "created_at" => "2006/08/01", "awesome" => true} +      #   #      "created_at" => "2006-08-01T17:27:13.000Z", "awesome" => true}        #        # The <tt>:only</tt> and <tt>:except</tt> options can be used to limit        # the attributes included, and work similar to the +attributes+ method. @@ -63,14 +63,14 @@ module ActiveModel        #        #   user.as_json(methods: :permalink)        #   # => { "id" => 1, "name" => "Konata Izumi", "age" => 16, -      #   #      "created_at" => "2006/08/01", "awesome" => true, +      #   #      "created_at" => "2006-08-01T17:27:13.000Z", "awesome" => true,        #   #      "permalink" => "1-konata-izumi" }        #        # To include associations use <tt>:include</tt>:        #        #   user.as_json(include: :posts)        #   # => { "id" => 1, "name" => "Konata Izumi", "age" => 16, -      #   #      "created_at" => "2006/08/01", "awesome" => true, +      #   #      "created_at" => "2006-08-01T17:27:13.000Z", "awesome" => true,        #   #      "posts" => [ { "id" => 1, "author_id" => 1, "title" => "Welcome to the weblog" },        #   #                   { "id" => 2, "author_id" => 1, "title" => "So I was thinking" } ] }        # @@ -81,7 +81,7 @@ module ActiveModel        #                                             only: :body } },        #                              only: :title } })        #   # => { "id" => 1, "name" => "Konata Izumi", "age" => 16, -      #   #      "created_at" => "2006/08/01", "awesome" => true, +      #   #      "created_at" => "2006-08-01T17:27:13.000Z", "awesome" => true,        #   #      "posts" => [ { "comments" => [ { "body" => "1st post!" }, { "body" => "Second!" } ],        #   #                     "title" => "Welcome to the weblog" },        #   #                   { "comments" => [ { "body" => "Don't think too hard" } ], @@ -93,11 +93,12 @@ module ActiveModel            include_root_in_json          end +        hash = serializable_hash(options).as_json          if root            root = model_name.element if root == true -          { root => serializable_hash(options) } +          { root => hash }          else -          serializable_hash(options) +          hash          end        end diff --git a/activemodel/lib/active_model/validations/numericality.rb b/activemodel/lib/active_model/validations/numericality.rb index 0478915be7..3753040316 100644 --- a/activemodel/lib/active_model/validations/numericality.rb +++ b/activemodel/lib/active_model/validations/numericality.rb @@ -23,6 +23,8 @@ module ActiveModel          if record.respond_to?(came_from_user) && record.public_send(came_from_user)            raw_value = record.read_attribute_before_type_cast(attr_name) +        elsif record.respond_to?(:read_attribute) +          raw_value = record.read_attribute(attr_name)          end          raw_value ||= value | 
