diff options
author | Joshua Peek <josh@joshpeek.com> | 2009-06-28 22:12:10 -0500 |
---|---|---|
committer | Joshua Peek <josh@joshpeek.com> | 2009-07-03 21:38:14 -0500 |
commit | d2b78b3594b9cc9870e6a6ebfeb2e56d00e6ddb8 (patch) | |
tree | 4465b03c54482abc2ffad18b93694b9de08cdb8b /activemodel/lib/active_model/serializers/json.rb | |
parent | e3d6d10e1ff669430c3d8678c196c52397c850ea (diff) | |
download | rails-d2b78b3594b9cc9870e6a6ebfeb2e56d00e6ddb8.tar.gz rails-d2b78b3594b9cc9870e6a6ebfeb2e56d00e6ddb8.tar.bz2 rails-d2b78b3594b9cc9870e6a6ebfeb2e56d00e6ddb8.zip |
Initial extraction of AMo xml serializer
Diffstat (limited to 'activemodel/lib/active_model/serializers/json.rb')
-rw-r--r-- | activemodel/lib/active_model/serializers/json.rb | 34 |
1 files changed, 19 insertions, 15 deletions
diff --git a/activemodel/lib/active_model/serializers/json.rb b/activemodel/lib/active_model/serializers/json.rb index 440fe47e34..0636e8c330 100644 --- a/activemodel/lib/active_model/serializers/json.rb +++ b/activemodel/lib/active_model/serializers/json.rb @@ -1,7 +1,5 @@ require 'active_support/json' require 'active_support/core_ext/class/attribute_accessors' -require 'active_support/core_ext/hash/except' -require 'active_support/core_ext/hash/slice' module ActiveModel module Serializers @@ -15,26 +13,32 @@ module ActiveModel cattr_accessor :include_root_in_json, :instance_writer => false end - def encode_json(encoder) - options = encoder.options || {} - - hash = if options[:only] - only = Array.wrap(options[:only]).map { |attr| attr.to_s } - attributes.slice(*only) - elsif options[:except] - except = Array.wrap(options[:except]).map { |attr| attr.to_s } - attributes.except(*except) - else - attributes + class Serializer < ActiveModel::Serializer + def serializable_hash + model = super + if @serializable.include_root_in_json + model = { @serializable.class.model_name.element => model } + end + model + end + + def serialize + ActiveSupport::JSON.encode(serializable_hash) end + end - hash = { self.class.model_name.element => hash } if include_root_in_json - ActiveSupport::JSON.encode(hash) + def encode_json(encoder) + Serializer.new(self, encoder.options).to_s end def as_json(options = nil) self end + + def from_json(json) + self.attributes = ActiveSupport::JSON.decode(json) + self + end end end end |