Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,17 @@ module RestPack
module Serializer
class SideLoadDataBuilder

def initialize(association, models, serializer)
def initialize(association, models, serializer, root_options)
@association = association
@models = models
@serializer = serializer
@root_options = root_options
end

def side_load_belongs_to
foreign_keys = @models.map { |model| model.send(@association.foreign_key) }.uniq.compact
side_load = foreign_keys.any? ? @association.klass.find(foreign_keys) : []
json_model_data = side_load.map { |model| @serializer.as_json(model) }
json_model_data = side_load.map { |model| @serializer.as_json(model, @root_options.context) }
{ @association.plural_name.to_sym => json_model_data, meta: { } }
end

Expand Down Expand Up @@ -46,7 +47,7 @@ def model_ids
def has_association_relation
return {} if @models.empty?
serializer_class = @serializer.class
options = RestPack::Serializer::Options.new(serializer_class)
options = RestPack::Serializer::Options.new(serializer_class, {}, nil, @root_options.context)
yield options
options.include_links = false
serializer_class.page_with_options(options)
Expand Down
3 changes: 2 additions & 1 deletion lib/restpack_serializer/serializable/side_loading.rb
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,8 @@ def side_load(include, models, options)
serializer = RestPack::Serializer::Factory.create(association.class_name)
builder = RestPack::Serializer::SideLoadDataBuilder.new(association,
models,
serializer)
serializer,
options)
builder.send("side_load_#{association.macro}")
end

Expand Down