mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-23 06:16:50 +00:00
Merge pull request #790 from engineyard/array-serializer-context
pass context to ArraySerializer
This commit is contained in:
commit
f71ac766ef
@ -15,17 +15,18 @@ module ActiveModel
|
|||||||
@object = object
|
@object = object
|
||||||
@scope = options[:scope]
|
@scope = options[:scope]
|
||||||
@root = options.fetch(:root, self.class._root)
|
@root = options.fetch(:root, self.class._root)
|
||||||
@polymorphic = options.fetch(:polymorphic, false)
|
@polymorphic = options.fetch(:polymorphic, false)
|
||||||
@meta_key = options[:meta_key] || :meta
|
@meta_key = options[:meta_key] || :meta
|
||||||
@meta = options[@meta_key]
|
@meta = options[@meta_key]
|
||||||
@each_serializer = options[:each_serializer]
|
@each_serializer = options[:each_serializer]
|
||||||
@resource_name = options[:resource_name]
|
@resource_name = options[:resource_name]
|
||||||
@only = options[:only] ? Array(options[:only]) : nil
|
@only = options[:only] ? Array(options[:only]) : nil
|
||||||
@except = options[:except] ? Array(options[:except]) : nil
|
@except = options[:except] ? Array(options[:except]) : nil
|
||||||
|
@context = options[:context]
|
||||||
@namespace = options[:namespace]
|
@namespace = options[:namespace]
|
||||||
@key_format = options[:key_format] || options[:each_serializer].try(:key_format)
|
@key_format = options[:key_format] || options[:each_serializer].try(:key_format)
|
||||||
end
|
end
|
||||||
attr_accessor :object, :scope, :root, :meta_key, :meta, :key_format
|
attr_accessor :object, :scope, :root, :meta_key, :meta, :key_format, :context
|
||||||
|
|
||||||
def json_key
|
def json_key
|
||||||
key = root.nil? ? @resource_name : root
|
key = root.nil? ? @resource_name : root
|
||||||
@ -35,7 +36,7 @@ module ActiveModel
|
|||||||
|
|
||||||
def serializer_for(item)
|
def serializer_for(item)
|
||||||
serializer_class = @each_serializer || Serializer.serializer_for(item, namespace: @namespace) || DefaultSerializer
|
serializer_class = @each_serializer || Serializer.serializer_for(item, namespace: @namespace) || DefaultSerializer
|
||||||
serializer_class.new(item, scope: scope, key_format: key_format, only: @only, except: @except, polymorphic: @polymorphic, namespace: @namespace)
|
serializer_class.new(item, scope: scope, key_format: key_format, context: @context, only: @only, except: @except, polymorphic: @polymorphic, namespace: @namespace)
|
||||||
end
|
end
|
||||||
|
|
||||||
def serializable_object(options={})
|
def serializable_object(options={})
|
||||||
@ -66,7 +67,7 @@ module ActiveModel
|
|||||||
private
|
private
|
||||||
|
|
||||||
def instrumentation_keys
|
def instrumentation_keys
|
||||||
[:object, :scope, :root, :meta_key, :meta, :each_serializer, :resource_name, :key_format]
|
[:object, :scope, :root, :meta_key, :meta, :each_serializer, :resource_name, :key_format, :context]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
16
test/unit/active_model/array_serializer/options_test.rb
Normal file
16
test/unit/active_model/array_serializer/options_test.rb
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
require 'test_helper'
|
||||||
|
|
||||||
|
module ActiveModel
|
||||||
|
class ArraySerializer
|
||||||
|
class OptionsTest < Minitest::Test
|
||||||
|
def test_custom_options_are_accessible_from_serializer
|
||||||
|
|
||||||
|
array = [Profile.new({ name: 'Name 1', description: 'Description 1', comments: 'Comments 1' }),
|
||||||
|
Profile.new({ name: 'Name 2', description: 'Description 2', comments: 'Comments 2' })]
|
||||||
|
serializer = ArraySerializer.new(array, only: [:name], context: {foo: :bar})
|
||||||
|
|
||||||
|
assert_equal({foo: :bar}, serializer.context)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
Loading…
Reference in New Issue
Block a user