diff options
Diffstat (limited to 'activemodel/lib/active_model/serialization.rb')
| -rw-r--r-- | activemodel/lib/active_model/serialization.rb | 43 | 
1 files changed, 35 insertions, 8 deletions
| diff --git a/activemodel/lib/active_model/serialization.rb b/activemodel/lib/active_model/serialization.rb index c06a64c75f..70e10fa06d 100644 --- a/activemodel/lib/active_model/serialization.rb +++ b/activemodel/lib/active_model/serialization.rb @@ -31,16 +31,14 @@ module ActiveModel    # of the attributes hash's keys. In order to override this behavior, take a look    # at the private method +read_attribute_for_serialization+.    # -  # Most of the time though, either the JSON or XML serializations are needed. -  # Both of these modules automatically include the -  # <tt>ActiveModel::Serialization</tt> module, so there is no need to -  # explicitly include it. +  # ActiveModel::Serializers::JSON module automatically includes +  # the <tt>ActiveModel::Serialization</tt> module, so there is no need to +  # explicitly include <tt>ActiveModel::Serialization</tt>.    # -  # A minimal implementation including XML and JSON would be: +  # A minimal implementation including JSON would be:    #    #   class Person    #     include ActiveModel::Serializers::JSON -  #     include ActiveModel::Serializers::Xml    #    #     attr_accessor :name    # @@ -55,13 +53,11 @@ module ActiveModel    #   person.serializable_hash   # => {"name"=>nil}    #   person.as_json             # => {"name"=>nil}    #   person.to_json             # => "{\"name\":null}" -  #   person.to_xml              # => "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<serial-person...    #    #   person.name = "Bob"    #   person.serializable_hash   # => {"name"=>"Bob"}    #   person.as_json             # => {"name"=>"Bob"}    #   person.to_json             # => "{\"name\":\"Bob\"}" -  #   person.to_xml              # => "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<serial-person...    #    # Valid options are <tt>:only</tt>, <tt>:except</tt>, <tt>:methods</tt> and    # <tt>:include</tt>. The following are all valid examples: @@ -94,6 +90,37 @@ module ActiveModel      #   person.serializable_hash(except: :name) # => {"age"=>22}      #   person.serializable_hash(methods: :capitalized_name)      #   # => {"name"=>"bob", "age"=>22, "capitalized_name"=>"Bob"} +    # +    # Example with <tt>:include</tt> option +    # +    #   class User +    #     include ActiveModel::Serializers::JSON +    #     attr_accessor :name, :notes # Emulate has_many :notes +    #     def attributes +    #       {'name' => nil} +    #     end +    #   end +    # +    #   class Note +    #     include ActiveModel::Serializers::JSON +    #     attr_accessor :title, :text +    #     def attributes +    #       {'title' => nil, 'text' => nil} +    #     end +    #   end +    # +    #   note = Note.new +    #   note.title = 'Battle of Austerlitz' +    #   note.text = 'Some text here' +    # +    #   user = User.new +    #   user.name = 'Napoleon' +    #   user.notes = [note] +    # +    #   user.serializable_hash +    #   # => {"name" => "Napoleon"} +    #   user.serializable_hash(include: { notes: { only: 'title' }}) +    #   # => {"name" => "Napoleon", "notes" => [{"title"=>"Battle of Austerlitz"}]}      def serializable_hash(options = nil)        options ||= {} | 
