Skip to content

Commit bbcb7bc

Browse files
committed
Move serialization logic into Serializer and CollectionSerializer
1 parent 064273d commit bbcb7bc

File tree

3 files changed

+30
-39
lines changed

3 files changed

+30
-39
lines changed

lib/active_model/serializer.rb

Lines changed: 19 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -98,6 +98,7 @@ def self.get_serializer_for(klass)
9898
end
9999
end
100100

101+
# @api private
101102
def self.include_directive_from_options(options)
102103
if options[:include_directive]
103104
options[:include_directive]
@@ -161,9 +162,9 @@ def success?
161162
# serializer.as_json(include: { posts: { include: { comments: { only: :body } }, only: :title } })
162163
def serializable_hash(adapter_opts = nil)
163164
adapter_opts ||= {}
164-
adapter_opts = { include: '*', adapter: :attributes }.merge!(adapter_opts)
165-
adapter = ActiveModelSerializers::Adapter.create(self, adapter_opts)
166-
adapter.serializable_hash(adapter_opts)
165+
adapter_opts = { include: '*' }.merge!(adapter_opts)
166+
adapter_instance = ActiveModelSerializers::Adapter::Attributes.new(self, adapter_opts)
167+
serialize(adapter_opts, {}, adapter_instance)
167168
end
168169
alias to_hash serializable_hash
169170
alias to_h serializable_hash
@@ -195,33 +196,38 @@ def read_attribute_for_serialization(attr)
195196
end
196197
end
197198

198-
def serializable_hash_for_single_resource(adapter_options, options, adapter_instance)
199+
# @api private
200+
def serialize(adapter_options, options, adapter_instance)
201+
options[:include_directive] ||= ActiveModel::Serializer.include_directive_from_options(adapter_options)
199202
cached_attributes = adapter_options[:cached_attributes] ||= {}
200203
resource = cached_attributes(options[:fields], cached_attributes, adapter_instance)
201-
relationships = resource_relationships(options)
204+
relationships = resource_relationships(adapter_options, options, adapter_instance)
202205
resource.merge(relationships)
203206
end
204207

205-
def resource_relationships(options)
208+
# @api private
209+
def resource_relationships(adapter_options, options, adapter_instance)
206210
relationships = {}
207211
include_directive = options.fetch(:include_directive)
208212
associations(include_directive).each do |association|
209-
relationships[association.key] ||= relationship_value_for(association, options)
213+
adapter_opts = adapter_options.merge(include_directive: include_directive[association.key])
214+
relationships[association.key] ||= relationship_value_for(association, adapter_opts, adapter_instance)
210215
end
211216

212217
relationships
213218
end
214219

215-
def relationship_value_for(association, options)
220+
# @api private
221+
def relationship_value_for(association, adapter_options, adapter_instance)
216222
return association.options[:virtual_value] if association.options[:virtual_value]
217-
return unless association.serializer && association.serializer.object
223+
association_serializer = association.serializer
224+
association_object = association_serializer && association_serializer.object
225+
return unless association_object
218226

219-
include_directive = options.fetch(:include_directive)
220-
opts = instance_options.merge(include_directive: include_directive[association.key])
221-
relationship_value = ActiveModelSerializers::Adapter::Attributes.new(association.serializer, opts).serializable_hash(options)
227+
relationship_value = association_serializer.serialize(adapter_options, {}, adapter_instance)
222228

223229
if association.options[:polymorphic] && relationship_value
224-
polymorphic_type = association.serializer.object.class.name.underscore
230+
polymorphic_type = association_object.class.name.underscore
225231
relationship_value = { type: polymorphic_type, polymorphic_type.to_sym => relationship_value }
226232
end
227233

lib/active_model/serializer/collection_serializer.rb

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -56,6 +56,16 @@ def paginated?
5656
object.respond_to?(:size)
5757
end
5858

59+
# @api private
60+
def serialize(adapter_options, options, adapter_instance)
61+
include_directive = ActiveModel::Serializer.include_directive_from_options(adapter_options)
62+
adapter_options[:cached_attributes] ||= ActiveModel::Serializer.cache_read_multi(self, adapter_instance, include_directive)
63+
adapter_opts = adapter_options.merge(include_directive: include_directive)
64+
serializers.map do |serializer|
65+
serializer.serialize(adapter_opts, options, adapter_instance)
66+
end
67+
end
68+
5969
protected
6070

6171
attr_reader :serializers, :options

lib/active_model_serializers/adapter/attributes.rb

Lines changed: 1 addition & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -1,34 +1,9 @@
11
module ActiveModelSerializers
22
module Adapter
33
class Attributes < Base
4-
def initialize(serializer, options = {})
5-
super
6-
end
7-
84
def serializable_hash(options = nil)
95
options = serialization_options(options)
10-
11-
if serializer.respond_to?(:each)
12-
serializable_hash_for_collection(serializer, options)
13-
else
14-
serializable_hash_for_single_resource(serializer, instance_options, options)
15-
end
16-
end
17-
18-
private
19-
20-
def serializable_hash_for_collection(serializers, options)
21-
include_directive = ActiveModel::Serializer.include_directive_from_options(instance_options)
22-
instance_options[:cached_attributes] ||= ActiveModel::Serializer.cache_read_multi(serializers, self, include_directive)
23-
instance_opts = instance_options.merge(include_directive: include_directive)
24-
serializers.map do |serializer|
25-
serializable_hash_for_single_resource(serializer, instance_opts, options)
26-
end
27-
end
28-
29-
def serializable_hash_for_single_resource(serializer, instance_options, options)
30-
options[:include_directive] ||= ActiveModel::Serializer.include_directive_from_options(instance_options)
31-
serializer.serializable_hash_for_single_resource(instance_options, options, self)
6+
serializer.serialize(instance_options, options, self)
327
end
338
end
349
end

0 commit comments

Comments
 (0)