diff --git a/ActionController.html b/ActionController.html deleted file mode 100644 index abf18c10..00000000 --- a/ActionController.html +++ /dev/null @@ -1,115 +0,0 @@ - - - - - - Module: ActionController - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActionController - - - -

- -
- - - - - - - - -
Defined in:
-
lib/action_controller/serialization.rb
- -
-
- -

Defined Under Namespace

-

- - - Modules: Serialization - - - - -

- - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/ActionController/Serialization.html b/ActionController/Serialization.html deleted file mode 100644 index bc98e40c..00000000 --- a/ActionController/Serialization.html +++ /dev/null @@ -1,348 +0,0 @@ - - - - - - Module: ActionController::Serialization - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActionController::Serialization - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Concern
- - - - -
Includes:
-
Renderers
- - - - - -
Defined in:
-
lib/action_controller/serialization.rb
- -
-
- -

Defined Under Namespace

-

- - - Modules: ClassMethods - - - - -

- - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) get_serializer(resource, options = {}) - - - - - -

- - - - -
-
-
-
-26
-27
-28
-29
-30
-31
-32
-33
-34
-35
-36
-37
-38
-39
-
-
# File 'lib/action_controller/serialization.rb', line 26
-
-def get_serializer(resource, options = {})
-  if !use_adapter?
-    warn 'ActionController::Serialization#use_adapter? has been removed. '\
-      "Please pass 'adapter: false' or see ActiveSupport::SerializableResource.new"
-    options[:adapter] = false
-  end
-  serializable_resource = ActiveModelSerializers::SerializableResource.new(resource, options)
-  serializable_resource.serialization_scope ||= options.fetch(:scope) { serialization_scope }
-  serializable_resource.serialization_scope_name = options.fetch(:scope_name) { _serialization_scope }
-  # For compatibility with the JSON renderer: `json.to_json(options) if json.is_a?(String)`.
-  # Otherwise, since `serializable_resource` is not a string, the renderer would call
-  # `to_json` on a String and given odd results, such as `"".to_json #=> '""'`
-  serializable_resource.adapter.is_a?(String) ? serializable_resource.adapter : serializable_resource
-end
-
-
- -
-

- - - (Object) serialization_scope - - - - - -

- - - - -
-
-
-
-21
-22
-23
-24
-
-
# File 'lib/action_controller/serialization.rb', line 21
-
-def serialization_scope
-  send(_serialization_scope) if _serialization_scope &&
-    respond_to?(_serialization_scope, true)
-end
-
-
- -
-

- - - (Boolean) use_adapter? - - - - - -

-
- -

Deprecated

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-42
-43
-44
-
-
# File 'lib/action_controller/serialization.rb', line 42
-
-def use_adapter?
-  true
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActionController/Serialization/ClassMethods.html b/ActionController/Serialization/ClassMethods.html deleted file mode 100644 index 05962a28..00000000 --- a/ActionController/Serialization/ClassMethods.html +++ /dev/null @@ -1,174 +0,0 @@ - - - - - - Module: ActionController::Serialization::ClassMethods - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActionController::Serialization::ClassMethods - - - -

- -
- - - - - - - - -
Defined in:
-
lib/action_controller/serialization.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) serialization_scope(scope) - - - - - -

- - - - -
-
-
-
-11
-12
-13
-
-
# File 'lib/action_controller/serialization.rb', line 11
-
-def serialization_scope(scope)
-  self._serialization_scope = scope
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel.html b/ActiveModel.html deleted file mode 100644 index 2ce61528..00000000 --- a/ActiveModel.html +++ /dev/null @@ -1,129 +0,0 @@ - - - - - - Module: ActiveModel - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model/serializer.rb,
- lib/active_model/serializer/type.rb,
lib/active_model/serializer/null.rb,
lib/active_model/serializer/meta.rb,
lib/active_model/serializer/field.rb,
lib/active_model/serializer/links.rb,
lib/active_model/serializer/adapter.rb,
lib/active_model/serializer/version.rb,
lib/active_model/serializer/caching.rb,
lib/active_model/serializer/fieldset.rb,
lib/active_model/serializer/attribute.rb,
lib/active_model/serializer/reflection.rb,
lib/active_model/serializable_resource.rb,
lib/active_model/serializer/attributes.rb,
lib/active_model/serializer/association.rb,
lib/active_model/serializer/associations.rb,
lib/active_model/serializer/adapter/json.rb,
lib/active_model/serializer/adapter/null.rb,
lib/active_model/serializer/adapter/base.rb,
lib/active_model/serializer/configuration.rb,
lib/active_model/serializer/adapter/json_api.rb,
lib/active_model/serializer/has_one_reflection.rb,
lib/active_model/serializer/adapter/attributes.rb,
lib/active_model/serializer/singular_reflection.rb,
lib/active_model/serializer/has_many_reflection.rb,
lib/active_model/serializer/collection_reflection.rb,
lib/active_model/serializer/belongs_to_reflection.rb,
lib/active_model/serializer/collection_serializer.rb
-
- -
-
- -

Overview

-
- -

ActiveModel::Serializer is an abstract class that is reified when -subclassed to decorate a resource.

- - -
-
-
- - -

Defined Under Namespace

-

- - - - - Classes: SerializableResource, Serializer - - -

- - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/SerializableResource.html b/ActiveModel/SerializableResource.html deleted file mode 100644 index 9f3a6947..00000000 --- a/ActiveModel/SerializableResource.html +++ /dev/null @@ -1,135 +0,0 @@ - - - - - - Class: ActiveModel::SerializableResource - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::SerializableResource - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - -
Extended by:
-
ActiveModelSerializers::Deprecate
- - - - - - - -
Defined in:
-
lib/active_model/serializable_resource.rb
- -
-
- - - - - - - - - - - - - - - -

Method Summary

- -

Methods included from ActiveModelSerializers::Deprecate

-

delegate_and_deprecate, deprecate

- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer.html b/ActiveModel/Serializer.html deleted file mode 100644 index ccbfbfa0..00000000 --- a/ActiveModel/Serializer.html +++ /dev/null @@ -1,1764 +0,0 @@ - - - - - - Class: ActiveModel::Serializer - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - -
Extended by:
-
ActiveModelSerializers::Deprecate, ActiveSupport::Autoload
- - - - -
Includes:
-
Associations, Attributes, Caching, Configuration, Links, Meta, Type
- - - - - -
Defined in:
-
lib/active_model/serializer.rb,
- lib/active_model/serializer/type.rb,
lib/active_model/serializer/null.rb,
lib/active_model/serializer/meta.rb,
lib/active_model/serializer/field.rb,
lib/active_model/serializer/links.rb,
lib/active_model/serializer/adapter.rb,
lib/active_model/serializer/version.rb,
lib/active_model/serializer/caching.rb,
lib/active_model/serializer/fieldset.rb,
lib/active_model/serializer/attribute.rb,
lib/active_model/serializer/reflection.rb,
lib/active_model/serializer/attributes.rb,
lib/active_model/serializer/association.rb,
lib/active_model/serializer/associations.rb,
lib/active_model/serializer/adapter/json.rb,
lib/active_model/serializer/adapter/null.rb,
lib/active_model/serializer/adapter/base.rb,
lib/active_model/serializer/configuration.rb,
lib/active_model/serializer/adapter/json_api.rb,
lib/active_model/serializer/array_serializer.rb,
lib/active_model/serializer/has_one_reflection.rb,
lib/active_model/serializer/adapter/attributes.rb,
lib/active_model/serializer/singular_reflection.rb,
lib/active_model/serializer/has_many_reflection.rb,
lib/active_model/serializer/collection_reflection.rb,
lib/active_model/serializer/belongs_to_reflection.rb,
lib/active_model/serializer/collection_serializer.rb
-
- -
-
- -
-

Direct Known Subclasses

-

ErrorSerializer, Null

-
-

Defined Under Namespace

-

- - - Modules: Adapter, Associations, Attributes, Caching, Configuration, Links, Lint, Meta, Type - - - - Classes: ArraySerializer, Association, Attribute, BelongsToReflection, CollectionReflection, CollectionSerializer, ErrorSerializer, ErrorsSerializer, Field, Fieldset, HasManyReflection, HasOneReflection, Null, Reflection, SingularReflection - - -

- -

Constant Summary

- -
- -
SERIALIZABLE_HASH_VALID_KEYS = -
-
- - -
-
-
- - -

See Also:

- - -
-
-
[:only, :except, :methods, :include, :root].freeze
- -
VERSION = - -
-
'0.10.0'.freeze
- -
UndefinedCacheKey = - -
-
Class.new(StandardError)
- -
- - - - - - -

Constants included - from Caching

-

Caching::CALLER_FILE

- - -

Instance Attribute Summary (collapse)

- - - - - - -

- Class Method Summary - (collapse) -

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods included from ActiveModelSerializers::Deprecate

-

delegate_and_deprecate, deprecate

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

Methods included from Caching

-

#cache_key, #fetch, #fetch_attributes, #fetch_attributes_fragment, #object_cache_key, #serializer_class

- - - - - - - - - - - - - - - - - -

Methods included from Associations

-

#associations

- - - - - - - - - -
-

Constructor Details

- -
-

- - - (Serializer) initialize(object, options = {}) - - - - - -

-
- -

`scope_name` is set as :current_user by default in the controller. If the -instance does not have a method named `scope_name`, it defines the method -so that it calls the scope.

- - -
-
-
- - -
- - - - -
-
-
-
-122
-123
-124
-125
-126
-127
-128
-129
-130
-131
-132
-
-
# File 'lib/active_model/serializer.rb', line 122
-
-def initialize(object, options = {})
-  self.object = object
-  self.instance_options = options
-  self.root = instance_options[:root]
-  self.scope = instance_options[:scope]
-
-  scope_name = instance_options[:scope_name]
-  if scope_name && !respond_to?(scope_name)
-    define_singleton_method scope_name, lambda { scope }
-  end
-end
-
-
- -
- -
-

Instance Attribute Details

- - - -
-

- - - (Object) object - - - - - -

-
- -

Returns the value of attribute object

- - -
-
-
- - -
- - - - -
-
-
-
-117
-118
-119
-
-
# File 'lib/active_model/serializer.rb', line 117
-
-def object
-  @object
-end
-
-
- - - -
-

- - - (Object) root - - - - - -

-
- -

Returns the value of attribute root

- - -
-
-
- - -
- - - - -
-
-
-
-117
-118
-119
-
-
# File 'lib/active_model/serializer.rb', line 117
-
-def root
-  @root
-end
-
-
- - - -
-

- - - (Object) scope - - - - - -

-
- -

Returns the value of attribute scope

- - -
-
-
- - -
- - - - -
-
-
-
-117
-118
-119
-
-
# File 'lib/active_model/serializer.rb', line 117
-
-def scope
-  @scope
-end
-
-
- -
- - -
-

Class Method Details

- - -
-

- - + (Object) adapter - - - - - -

-
- -

Deprecated

- - -
-
-
- - -

See Also:

- - -
- - - - -
-
-
-
-53
-54
-55
-
-
# File 'lib/active_model/serializer.rb', line 53
-
-def self.adapter
-  ActiveModelSerializers::Adapter.lookup(config.adapter)
-end
-
-
- -
-

- - + (Object) get_serializer_for(klass) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- -

Find a serializer from a class and caches the lookup. Preferentially -returns:

- -
1. class name appended with "Serializer"
-2. try again with superclass, if present
-3. nil
- - -
-
-
- - -
- - - - -
-
-
-
-87
-88
-89
-90
-91
-92
-93
-94
-95
-96
-97
-98
-99
-
-
# File 'lib/active_model/serializer.rb', line 87
-
-def self.get_serializer_for(klass)
-  return nil unless config.serializer_lookup_enabled
-  serializers_cache.fetch_or_store(klass) do
-    # NOTE(beauby): When we drop 1.9.3 support we can lazify the map for perfs.
-    serializer_class = serializer_lookup_chain_for(klass).map(&:safe_constantize).find { |x| x && x < ActiveModel::Serializer }
-
-    if serializer_class
-      serializer_class
-    elsif klass.superclass
-      get_serializer_for(klass.superclass)
-    end
-  end
-end
-
-
- -
-

- - + (Object) include_directive_from_options(options) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - -
-
-
-
-102
-103
-104
-105
-106
-107
-108
-109
-110
-
-
# File 'lib/active_model/serializer.rb', line 102
-
-def self.include_directive_from_options(options)
-  if options[:include_directive]
-    options[:include_directive]
-  elsif options[:include]
-    JSONAPI::IncludeDirective.new(options[:include], allow_wildcard: true)
-  else
-    ActiveModelSerializers.default_include_directive
-  end
-end
-
-
- -
-

- - + (Object) serialization_adapter_instance - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - -
-
-
-
-113
-114
-115
-
-
# File 'lib/active_model/serializer.rb', line 113
-
-def self.serialization_adapter_instance
-  @serialization_adapter_instance ||= ActiveModelSerializers::Adapter::Attributes
-end
-
-
- -
-

- - + (ActiveModel::Serializer) serializer_for(resource, options = {}) - - - - - -

-
- -

Returns Preferentially returns

-
  1. -

    resource.serializer

    -
  2. -

    ArraySerializer when resource is a collection

    -
  3. -

    options

    -
  4. -

    lookup serializer when resource is a Class

    -
- - -
-
-
-

Parameters:

- - -

Returns:

-
    - -
  • - - - (ActiveModel::Serializer) - - - - — -
    -

    Preferentially returns

    -
    1. -

      resource.serializer

      -
    2. -

      ArraySerializer when resource is a collection

      -
    3. -

      options

      -
    4. -

      lookup serializer when resource is a Class

      -
    -
    - -
  • - -
- -
- - - - -
-
-
-
-41
-42
-43
-44
-45
-46
-47
-48
-49
-
-
# File 'lib/active_model/serializer.rb', line 41
-
-def self.serializer_for(resource, options = {})
-  if resource.respond_to?(:serializer_class)
-    resource.serializer_class
-  elsif resource.respond_to?(:to_ary)
-    config.collection_serializer
-  else
-    options.fetch(:serializer) { get_serializer_for(resource.class) }
-  end
-end
-
-
- -
-

- - + (Object) serializer_lookup_chain_for(klass) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - -
-
-
-
-62
-63
-64
-65
-66
-67
-68
-69
-70
-71
-72
-73
-
-
# File 'lib/active_model/serializer.rb', line 62
-
-def self.serializer_lookup_chain_for(klass)
-  chain = []
-
-  resource_class_name = klass.name.demodulize
-  resource_namespace = klass.name.deconstantize
-  serializer_class_name = "#{resource_class_name}Serializer"
-
-  chain.push("#{name}::#{serializer_class_name}") if self != ActiveModel::Serializer
-  chain.push("#{resource_namespace}::#{serializer_class_name}")
-
-  chain
-end
-
-
- -
-

- - + (Object) serializers_cache - - - - - -

-
- -

Used to cache serializer name => serializer class when looked up by -Serializer.get_serializer_for.

- - -
-
-
- - -
- - - - -
-
-
-
-77
-78
-79
-
-
# File 'lib/active_model/serializer.rb', line 77
-
-def self.serializers_cache
-  @serializers_cache ||= ThreadSafe::Cache.new
-end
-
-
- -
- -
-

Instance Method Details

- - -
-

- - - (Object) as_json(adapter_opts = nil) - - - - - -

-
- -

TODO: When moving attributes adapter logic here, @see #serializable_hash So -that the below is true:

- -
@param options [nil, Hash] The same valid options passed to `as_json`
-   (:root, :only, :except, :methods, and :include).
-The default for `root` is nil.
-The default value for include_root is false. You can change it to true if the given
-JSON string includes a single root node.
- - -
-
-
- - -

See Also:

- - -
- - - - -
-
-
-
-185
-186
-187
-
-
# File 'lib/active_model/serializer.rb', line 185
-
-def as_json(adapter_opts = nil)
-  serializable_hash(adapter_opts)
-end
-
-
- -
-

- - - (Object) json_key - - - - - -

-
- -

Used by adapter as resource root.

- - -
-
-
- - -
- - - - -
-
-
-
-190
-191
-192
-
-
# File 'lib/active_model/serializer.rb', line 190
-
-def json_key
-  root || _type || object.class.model_name.to_s.underscore
-end
-
-
- -
-

- - - (Object) read_attribute_for_serialization(attr) - - - - - -

- - - - -
-
-
-
-194
-195
-196
-197
-198
-199
-200
-
-
# File 'lib/active_model/serializer.rb', line 194
-
-def read_attribute_for_serialization(attr)
-  if respond_to?(attr)
-    send(attr)
-  else
-    object.read_attribute_for_serialization(attr)
-  end
-end
-
-
- -
-

- - - (Object) relationship_value_for(association, adapter_options, adapter_instance) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - -
-
-
-
-215
-216
-217
-218
-219
-220
-221
-222
-223
-224
-225
-226
-227
-228
-229
-
-
# File 'lib/active_model/serializer.rb', line 215
-
-def relationship_value_for(association, adapter_options, adapter_instance)
-  return association.options[:virtual_value] if association.options[:virtual_value]
-  association_serializer = association.serializer
-  association_object = association_serializer && association_serializer.object
-  return unless association_object
-
-  relationship_value = association_serializer.serializable_hash(adapter_options, {}, adapter_instance)
-
-  if association.options[:polymorphic] && relationship_value
-    polymorphic_type = association_object.class.name.underscore
-    relationship_value = { type: polymorphic_type, polymorphic_type.to_sym => relationship_value }
-  end
-
-  relationship_value
-end
-
-
- -
-

- - - (Object) resource_relationships(adapter_options, options, adapter_instance) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - -
-
-
-
-203
-204
-205
-206
-207
-208
-209
-210
-211
-212
-
-
# File 'lib/active_model/serializer.rb', line 203
-
-def resource_relationships(adapter_options, options, adapter_instance)
-  relationships = {}
-  include_directive = options.fetch(:include_directive)
-  associations(include_directive).each do |association|
-    adapter_opts = adapter_options.merge(include_directive: include_directive[association.key])
-    relationships[association.key] ||= relationship_value_for(association, adapter_opts, adapter_instance)
-  end
-
-  relationships
-end
-
-
- -
-

- - - (Hash) serializable_hash(adapter_options = nil, options = {}, adapter_instance = self.class.serialization_adapter_instance) - - - - Also known as: - to_hash, to_h - - - - -

-
- -

associations, similar to how ActiveModel::Serializers::JSON is used in -ActiveRecord::Base.

- -

TODO: Include ActiveModel::Serializers::JSON. So that the -below is true:

- -
@param options [nil, Hash] The same valid options passed to `serializable_hash`
-   (:only, :except, :methods, and :include).
-
-  See
-  https://github.com/rails/rails/blob/v5.0.0.beta2/activemodel/lib/active_model/serializers/json.rb#L17-L101
-  https://github.com/rails/rails/blob/v5.0.0.beta2/activemodel/lib/active_model/serialization.rb#L85-L123
-  https://github.com/rails/rails/blob/v5.0.0.beta2/activerecord/lib/active_record/serialization.rb#L11-L17
-  https://github.com/rails/rails/blob/v5.0.0.beta2/activesupport/lib/active_support/core_ext/object/json.rb#L147-L162
-
-@example
-  # The :only and :except options can be used to limit the attributes included, and work
-  # similar to the attributes method.
-  serializer.as_json(only: [:id, :name])
-  serializer.as_json(except: [:id, :created_at, :age])
-
-  # To include the result of some method calls on the model use :methods:
-  serializer.as_json(methods: :permalink)
-
-  # To include associations use :include:
-  serializer.as_json(include: :posts)
-  # Second level and higher order associations work as well:
-  serializer.as_json(include: { posts: { include: { comments: { only: :body } }, only: :title } })
- - -
-
-
- -

Returns:

-
    - -
  • - - - (Hash) - - - - — -
    -

    containing the attributes and first level

    -
    - -
  • - -
- -
- - - - -
-
-
-
-166
-167
-168
-169
-170
-171
-172
-173
-
-
# File 'lib/active_model/serializer.rb', line 166
-
-def serializable_hash(adapter_options = nil, options = {}, adapter_instance = self.class.serialization_adapter_instance)
-  adapter_options ||= {}
-  options[:include_directive] ||= ActiveModel::Serializer.include_directive_from_options(adapter_options)
-  cached_attributes = adapter_options[:cached_attributes] ||= {}
-  resource = fetch_attributes(options[:fields], cached_attributes, adapter_instance)
-  relationships = resource_relationships(adapter_options, options, adapter_instance)
-  resource.merge(relationships)
-end
-
-
- -
-

- - - (Boolean) success? - - - - - -

-
- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-134
-135
-136
-
-
# File 'lib/active_model/serializer.rb', line 134
-
-def success?
-  true
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Adapter.html b/ActiveModel/Serializer/Adapter.html deleted file mode 100644 index 4e674a41..00000000 --- a/ActiveModel/Serializer/Adapter.html +++ /dev/null @@ -1,156 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Adapter - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Adapter - - Deprecated - -

- -
- - - -
Extended by:
-
ActiveModelSerializers::Deprecate
- - - - - - - -
Defined in:
-
lib/active_model/serializer/adapter.rb,
- lib/active_model/serializer/adapter/json.rb,
lib/active_model/serializer/adapter/null.rb,
lib/active_model/serializer/adapter/base.rb,
lib/active_model/serializer/adapter/json_api.rb,
lib/active_model/serializer/adapter/attributes.rb
-
- -
-
- -

Overview

-
-
Deprecated.
-

Use ActiveModelSerializers::Adapter instead

-
- - -
-
-
- - -

Defined Under Namespace

-

- - - - - Classes: Attributes, Base, Json, JsonApi, Null - - -

- -

Constant Summary

- -
- -
DEPRECATED_METHODS = - -
-
[:create, :adapter_class, :adapter_map, :adapters, :register, :lookup].freeze
- -
- - - - - - - - - - - - - - - -

Method Summary

- -

Methods included from ActiveModelSerializers::Deprecate

-

delegate_and_deprecate, deprecate

- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Adapter/Attributes.html b/ActiveModel/Serializer/Adapter/Attributes.html deleted file mode 100644 index 8d70fed4..00000000 --- a/ActiveModel/Serializer/Adapter/Attributes.html +++ /dev/null @@ -1,248 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::Adapter::Attributes - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::Adapter::Attributes - - - -

- -
- -
Inherits:
-
- ActiveModelSerializers::Adapter::Attributes - - - show all - -
- - - - -
Extended by:
-
ActiveModelSerializers::Deprecate
- - - - - - - -
Defined in:
-
lib/active_model/serializer/adapter/attributes.rb
- -
-
- - - - - - - -

Instance Attribute Summary

- -

Attributes inherited from ActiveModelSerializers::Adapter::Base

-

#instance_options, #serializer

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods included from ActiveModelSerializers::Deprecate

-

delegate_and_deprecate, deprecate

- - - - - - - - - -

Methods inherited from ActiveModelSerializers::Adapter::Attributes

-

#serializable_hash

- - - - - - - - - -

Methods inherited from ActiveModelSerializers::Adapter::Base

-

#as_json, cache_key, #cache_key, default_key_transform, #fragment_cache, fragment_cache, inherited, #serializable_hash, transform, transform_key_casing!

-
-

Constructor Details

- -
-

- - - (Attributes) initialize(serializer, options = {}) - - - - - -

-
- -

Returns a new instance of Attributes

- - -
-
-
- - -
- - - - -
-
-
-
-5
-6
-7
-
-
# File 'lib/active_model/serializer/adapter/attributes.rb', line 5
-
-def initialize(serializer, options = {})
-  super(ActiveModelSerializers::Adapter::Attributes.new(serializer, options))
-end
-
-
- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Adapter/Base.html b/ActiveModel/Serializer/Adapter/Base.html deleted file mode 100644 index df02d440..00000000 --- a/ActiveModel/Serializer/Adapter/Base.html +++ /dev/null @@ -1,235 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::Adapter::Base - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::Adapter::Base - - - -

- -
- -
Inherits:
-
- ActiveModelSerializers::Adapter::Base - - - show all - -
- - - - -
Extended by:
-
ActiveModelSerializers::Deprecate
- - - - - - - -
Defined in:
-
lib/active_model/serializer/adapter/base.rb
- -
-
- - - - - - - -

Instance Attribute Summary

- -

Attributes inherited from ActiveModelSerializers::Adapter::Base

-

#instance_options, #serializer

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods included from ActiveModelSerializers::Deprecate

-

delegate_and_deprecate, deprecate

- - - - - - - - - -

Methods inherited from ActiveModelSerializers::Adapter::Base

-

#as_json, cache_key, #cache_key, default_key_transform, #fragment_cache, fragment_cache, inherited, #serializable_hash, transform, transform_key_casing!

-
-

Constructor Details

- -
-

- - - (Base) initialize(serializer, options = {}) - - - - - -

-
- -

:nocov:

- - -
-
-
- - -
- - - - -
-
-
-
-11
-12
-13
-
-
# File 'lib/active_model/serializer/adapter/base.rb', line 11
-
-def initialize(serializer, options = {})
-  super(ActiveModelSerializers::Adapter::Base.new(serializer, options))
-end
-
-
- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Adapter/Json.html b/ActiveModel/Serializer/Adapter/Json.html deleted file mode 100644 index b8d81304..00000000 --- a/ActiveModel/Serializer/Adapter/Json.html +++ /dev/null @@ -1,248 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::Adapter::Json - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::Adapter::Json - - - -

- -
- -
Inherits:
-
- ActiveModelSerializers::Adapter::Json - - - show all - -
- - - - -
Extended by:
-
ActiveModelSerializers::Deprecate
- - - - - - - -
Defined in:
-
lib/active_model/serializer/adapter/json.rb
- -
-
- - - - - - - -

Instance Attribute Summary

- -

Attributes inherited from ActiveModelSerializers::Adapter::Base

-

#instance_options, #serializer

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods included from ActiveModelSerializers::Deprecate

-

delegate_and_deprecate, deprecate

- - - - - - - - - -

Methods inherited from ActiveModelSerializers::Adapter::Json

-

#meta, #meta_key, #serializable_hash

- - - - - - - - - -

Methods inherited from ActiveModelSerializers::Adapter::Base

-

#as_json, cache_key, #cache_key, default_key_transform, #fragment_cache, fragment_cache, inherited, #serializable_hash, transform, transform_key_casing!

-
-

Constructor Details

- -
-

- - - (Json) initialize(serializer, options = {}) - - - - - -

-
- -

Returns a new instance of Json

- - -
-
-
- - -
- - - - -
-
-
-
-5
-6
-7
-
-
# File 'lib/active_model/serializer/adapter/json.rb', line 5
-
-def initialize(serializer, options = {})
-  super(ActiveModelSerializers::Adapter::Json.new(serializer, options))
-end
-
-
- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Adapter/JsonApi.html b/ActiveModel/Serializer/Adapter/JsonApi.html deleted file mode 100644 index 4cde494b..00000000 --- a/ActiveModel/Serializer/Adapter/JsonApi.html +++ /dev/null @@ -1,249 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::Adapter::JsonApi - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::Adapter::JsonApi - - - -

- -
- -
Inherits:
-
- ActiveModelSerializers::Adapter::JsonApi - - - show all - -
- - - - -
Extended by:
-
ActiveModelSerializers::Deprecate
- - - - - - - -
Defined in:
-
lib/active_model/serializer/adapter/json_api.rb
- -
-
- - - - - - - -

Instance Attribute Summary

- -

Attributes inherited from ActiveModelSerializers::Adapter::Base

-

#instance_options, #serializer

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods included from ActiveModelSerializers::Deprecate

-

delegate_and_deprecate, deprecate

- - - - - - - - - -

Methods inherited from ActiveModelSerializers::Adapter::JsonApi

-

default_key_transform, #failure_document, #fragment_cache, fragment_cache, #serializable_hash, #success_document

- - - - - - - - - - -

Methods inherited from ActiveModelSerializers::Adapter::Base

-

#as_json, cache_key, #cache_key, default_key_transform, #fragment_cache, fragment_cache, inherited, #serializable_hash, transform, transform_key_casing!

-
-

Constructor Details

- -
-

- - - (JsonApi) initialize(serializer, options = {}) - - - - - -

-
- -

Returns a new instance of JsonApi

- - -
-
-
- - -
- - - - -
-
-
-
-5
-6
-7
-
-
# File 'lib/active_model/serializer/adapter/json_api.rb', line 5
-
-def initialize(serializer, options = {})
-  super(ActiveModelSerializers::Adapter::JsonApi.new(serializer, options))
-end
-
-
- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Adapter/Null.html b/ActiveModel/Serializer/Adapter/Null.html deleted file mode 100644 index e44619e0..00000000 --- a/ActiveModel/Serializer/Adapter/Null.html +++ /dev/null @@ -1,248 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::Adapter::Null - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::Adapter::Null - - - -

- -
- -
Inherits:
-
- ActiveModelSerializers::Adapter::Null - - - show all - -
- - - - -
Extended by:
-
ActiveModelSerializers::Deprecate
- - - - - - - -
Defined in:
-
lib/active_model/serializer/adapter/null.rb
- -
-
- - - - - - - -

Instance Attribute Summary

- -

Attributes inherited from ActiveModelSerializers::Adapter::Base

-

#instance_options, #serializer

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods included from ActiveModelSerializers::Deprecate

-

delegate_and_deprecate, deprecate

- - - - - - - - - -

Methods inherited from ActiveModelSerializers::Adapter::Null

-

#serializable_hash

- - - - - - - - - -

Methods inherited from ActiveModelSerializers::Adapter::Base

-

#as_json, cache_key, #cache_key, default_key_transform, #fragment_cache, fragment_cache, inherited, #serializable_hash, transform, transform_key_casing!

-
-

Constructor Details

- -
-

- - - (Null) initialize(serializer, options = {}) - - - - - -

-
- -

Returns a new instance of Null

- - -
-
-
- - -
- - - - -
-
-
-
-5
-6
-7
-
-
# File 'lib/active_model/serializer/adapter/null.rb', line 5
-
-def initialize(serializer, options = {})
-  super(ActiveModelSerializers::Adapter::Null.new(serializer, options))
-end
-
-
- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/ArraySerializer.html b/ActiveModel/Serializer/ArraySerializer.html deleted file mode 100644 index b11989fa..00000000 --- a/ActiveModel/Serializer/ArraySerializer.html +++ /dev/null @@ -1,169 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::ArraySerializer - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::ArraySerializer - - - -

- -
- -
Inherits:
-
- CollectionSerializer - - - show all - -
- - - - -
Extended by:
-
ActiveModelSerializers::Deprecate
- - - - - - - -
Defined in:
-
lib/active_model/serializer/array_serializer.rb
- -
-
- - -

Constant Summary

- - - - -

Constant Summary

- -

Constants inherited - from CollectionSerializer

-

CollectionSerializer::NoSerializerError

- - - - -

Instance Attribute Summary

- -

Attributes inherited from CollectionSerializer

-

#object, #root

- - - - - - - - - -

Method Summary

- -

Methods included from ActiveModelSerializers::Deprecate

-

delegate_and_deprecate, deprecate

- - - - - - - - - -

Methods inherited from CollectionSerializer

-

#initialize, #json_key, #paginated?, #serializable_hash, #success?

- -
-

Constructor Details

- -

This class inherits a constructor from ActiveModel::Serializer::CollectionSerializer

- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Association.html b/ActiveModel/Serializer/Association.html deleted file mode 100644 index 8110d31f..00000000 --- a/ActiveModel/Serializer/Association.html +++ /dev/null @@ -1,592 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::Association - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::Association - - - -

- -
- -
Inherits:
-
- Struct - -
    -
  • Object
  • - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model/serializer/association.rb
- -
-
- -

Overview

-
- -

This class hold all information about serializer's association.

- - -
-
-
- -
-

Examples:

- - -
Association.new(:comments, CommentSummarySerializer)
- -
- - -
- - - -

Instance Attribute Summary (collapse)

- - - - - - - -
-

Instance Attribute Details

- - - -
-
-
- -

Returns the value of attribute links

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Object) - - - - — -
    -

    the current value of links

    -
    - -
  • - -
- -
- - - - -
-
-
-
-12
-13
-14
-
-
# File 'lib/active_model/serializer/association.rb', line 12
-
-def links
-  @links
-end
-
-
- - - -
-

- - - (Object) meta - - - - - -

-
- -

Returns the value of attribute meta

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Object) - - - - — -
    -

    the current value of meta

    -
    - -
  • - -
- -
- - - - -
-
-
-
-12
-13
-14
-
-
# File 'lib/active_model/serializer/association.rb', line 12
-
-def meta
-  @meta
-end
-
-
- - - -
-

- - - (Symbol) name - - - - - -

-
- -

Returns the current value of name

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Symbol) - - - - — -
    -

    the current value of name

    -
    - -
  • - -
- -
- - - - -
-
-
-
-12
-13
-14
-
-
# File 'lib/active_model/serializer/association.rb', line 12
-
-def name
-  @name
-end
-
-
- - - -
-

- - - (Hash{Symbol => Object}) options - - - - - -

-
- -

Returns the current value of options

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Hash{Symbol => Object}) - - - - — -
    -

    the current value of options

    -
    - -
  • - -
- -
- - - - -
-
-
-
-12
-13
-14
-
-
# File 'lib/active_model/serializer/association.rb', line 12
-
-def options
-  @options
-end
-
-
- - - -
-

- - - (ActiveModel::Serializer) serializer - - - - - -

-
- -

Returns the current value of serializer

- - -
-
-
- -

Returns:

- - -
- - - - -
-
-
-
-12
-13
-14
-
-
# File 'lib/active_model/serializer/association.rb', line 12
-
-def serializer
-  @serializer
-end
-
-
- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Associations.html b/ActiveModel/Serializer/Associations.html deleted file mode 100644 index eb2ec1e1..00000000 --- a/ActiveModel/Serializer/Associations.html +++ /dev/null @@ -1,272 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Associations - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Associations - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Concern
- - - - - - -
Included in:
-
ActiveModel::Serializer
- - - -
Defined in:
-
lib/active_model/serializer/associations.rb
- -
-
- -

Overview

-
- -

Defines an association in the object should be rendered.

- -

The serializer object should implement the association name as a method -which should return an array when invoked. If a method with the association -name does not exist, the association name is dispatched to the serialized -object.

- - -
-
-
- - -

Defined Under Namespace

-

- - - Modules: ClassMethods - - - - -

- - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - - -
-

Instance Method Details

- - -
-

- - - (Enumerator<Association>) associations(include_directive = ActiveModelSerializers.default_include_directive) - - - - - -

-
- - -
-
-
-

Parameters:

-
    - -
  • - - include_directive - - - (JSONAPI::IncludeDirective) - - - (defaults to: ActiveModelSerializers.default_include_directive) - - - — -
    -

    (defaults to the default_include_directive config value when -not provided)

    -
    - -
  • - -
- -

Returns:

- - -
- - - - -
-
-
-
-85
-86
-87
-88
-89
-90
-91
-92
-93
-94
-95
-96
-
-
# File 'lib/active_model/serializer/associations.rb', line 85
-
-def associations(include_directive = ActiveModelSerializers.default_include_directive)
-  return unless object
-
-  Enumerator.new do |y|
-    self.class._reflections.each do |reflection|
-      next if reflection.excluded?(self)
-      key = reflection.options.fetch(:key, reflection.name)
-      next unless include_directive.key?(key)
-      y.yield reflection.build_association(self, instance_options)
-    end
-  end
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Associations/ClassMethods.html b/ActiveModel/Serializer/Associations/ClassMethods.html deleted file mode 100644 index ed26ab7c..00000000 --- a/ActiveModel/Serializer/Associations/ClassMethods.html +++ /dev/null @@ -1,497 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Associations::ClassMethods - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Associations::ClassMethods - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model/serializer/associations.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (void) belongs_to(name, options = {}, &block) - - - - - -

-
-

This method returns an undefined value.

- -
-
-
- -
-

Examples:

- - -
belongs_to :author, serializer: AuthorSerializer
- -
-

Parameters:

-
    - -
  • - - name - - - (Symbol) - - - - — -
    -

    of the association

    -
    - -
  • - -
  • - - options - - - (Hash<Symbol => any>) - - - (defaults to: {}) - - - — -
    -

    for the reflection

    -
    - -
  • - -
- - -
- - - - -
-
-
-
-53
-54
-55
-
-
# File 'lib/active_model/serializer/associations.rb', line 53
-
-def belongs_to(name, options = {}, &block)
-  associate(BelongsToReflection.new(name, options, block))
-end
-
-
- -
-

- - - (void) has_many(name, options = {}, &block) - - - - - -

-
-

This method returns an undefined value.

- -
-
-
- -
-

Examples:

- - -
has_many :comments, serializer: CommentSummarySerializer
- -
-

Parameters:

-
    - -
  • - - name - - - (Symbol) - - - - — -
    -

    of the association

    -
    - -
  • - -
  • - - options - - - (Hash<Symbol => any>) - - - (defaults to: {}) - - - — -
    -

    for the reflection

    -
    - -
  • - -
- - -
- - - - -
-
-
-
-42
-43
-44
-
-
# File 'lib/active_model/serializer/associations.rb', line 42
-
-def has_many(name, options = {}, &block)
-  associate(HasManyReflection.new(name, options, block))
-end
-
-
- -
-

- - - (void) has_one(name, options = {}, &block) - - - - - -

-
-

This method returns an undefined value.

- -
-
-
- -
-

Examples:

- - -
has_one :author, serializer: AuthorSerializer
- -
-

Parameters:

-
    - -
  • - - name - - - (Symbol) - - - - — -
    -

    of the association

    -
    - -
  • - -
  • - - options - - - (Hash<Symbol => any>) - - - (defaults to: {}) - - - — -
    -

    for the reflection

    -
    - -
  • - -
- - -
- - - - -
-
-
-
-64
-65
-66
-
-
# File 'lib/active_model/serializer/associations.rb', line 64
-
-def has_one(name, options = {}, &block)
-  associate(HasOneReflection.new(name, options, block))
-end
-
-
- -
-

- - - (Object) inherited(base) - - - - - -

- - - - -
-
-
-
-30
-31
-32
-33
-
-
# File 'lib/active_model/serializer/associations.rb', line 30
-
-def inherited(base)
-  super
-  base._reflections = _reflections.dup
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Attribute.html b/ActiveModel/Serializer/Attribute.html deleted file mode 100644 index f08ce23c..00000000 --- a/ActiveModel/Serializer/Attribute.html +++ /dev/null @@ -1,167 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::Attribute - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::Attribute - - - -

- -
- -
Inherits:
-
- Field - -
    -
  • Object
  • - - - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model/serializer/attribute.rb
- -
-
- -

Overview

-
- -

Holds all the meta-data about an attribute as it was specified in the -ActiveModel::Serializer class.

- - -
-
-
- -
-

Examples:

- - -
class PostSerializer < ActiveModel::Serializer
-  attribute :content
-  attribute :name, key: :title
-  attribute :email, key: :author_email, if: :user_logged_in?
-  attribute :preview do
-    truncate(object.content)
-  end
-
-  def user_logged_in?
-    current_user.logged_in?
-  end
-end
- -
- - -
- - - - - -

Instance Attribute Summary

- -

Attributes inherited from Field

-

#block, #name, #options

- - - - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Attributes.html b/ActiveModel/Serializer/Attributes.html deleted file mode 100644 index 44c100e3..00000000 --- a/ActiveModel/Serializer/Attributes.html +++ /dev/null @@ -1,124 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Attributes - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Attributes - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Concern
- - - - - - -
Included in:
-
ActiveModel::Serializer
- - - -
Defined in:
-
lib/active_model/serializer/attributes.rb
- -
-
- -

Defined Under Namespace

-

- - - Modules: ClassMethods - - - - -

- - - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Attributes/ClassMethods.html b/ActiveModel/Serializer/Attributes/ClassMethods.html deleted file mode 100644 index 5bba1a19..00000000 --- a/ActiveModel/Serializer/Attributes/ClassMethods.html +++ /dev/null @@ -1,497 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Attributes::ClassMethods - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Attributes::ClassMethods - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model/serializer/attributes.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) _attributes - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- -

keys of attributes

- - -
-
-
- - -

See Also:

-
    - -
  • Serializer::attribute
  • - -
- -
- - - - -
-
-
-
-64
-65
-66
-
-
# File 'lib/active_model/serializer/attributes.rb', line 64
-
-def _attributes
-  _attributes_data.keys
-end
-
-
- -
-

- - - (Object) _attributes_keys - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- -

maps attribute value to explict key name

- - -
-
-
- - -

See Also:

-
    - -
  • Serializer::attribute
  • - -
  • FragmentCache#fragment_serializer
  • - -
- -
- - - - -
-
-
-
-72
-73
-74
-75
-76
-77
-78
-
-
# File 'lib/active_model/serializer/attributes.rb', line 72
-
-def _attributes_keys
-  _attributes_data
-    .each_with_object({}) do |(key, attr), hash|
-      next if key == attr.name
-      hash[attr.name] = { key: key }
-    end
-end
-
-
- -
-

- - - (Object) attribute(attr, options = {}, &block) - - - - - -

-
- - -
-
-
- -
-

Examples:

- - -
class AdminAuthorSerializer < ActiveModel::Serializer
-  attributes :id, :recent_edits
-  attribute :name, key: :title
-
-  attribute :full_name do
-    "#{object.first_name} #{object.last_name}"
-  end
-
-  def recent_edits
-    object.edits.last(5)
-  end
- -
- - -
- - - - -
-
-
-
-56
-57
-58
-59
-
-
# File 'lib/active_model/serializer/attributes.rb', line 56
-
-def attribute(attr, options = {}, &block)
-  key = options.fetch(:key, attr)
-  _attributes_data[key] = Attribute.new(attr, options, block)
-end
-
-
- -
-

- - - (Object) attributes(*attrs) - - - - - -

-
- - -
-
-
- -
-

Examples:

- - -
class AdminAuthorSerializer < ActiveModel::Serializer
-  attributes :id, :name, :recent_edits
- -
- - -
- - - - -
-
-
-
-36
-37
-38
-39
-40
-41
-42
-
-
# File 'lib/active_model/serializer/attributes.rb', line 36
-
-def attributes(*attrs)
-  attrs = attrs.first if attrs.first.class == Array
-
-  attrs.each do |attr|
-    attribute(attr)
-  end
-end
-
-
- -
-

- - - (Object) inherited(base) - - - - - -

- - - - -
-
-
-
-28
-29
-30
-31
-
-
# File 'lib/active_model/serializer/attributes.rb', line 28
-
-def inherited(base)
-  super
-  base._attributes_data = _attributes_data.dup
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/BelongsToReflection.html b/ActiveModel/Serializer/BelongsToReflection.html deleted file mode 100644 index 7ce8ffb2..00000000 --- a/ActiveModel/Serializer/BelongsToReflection.html +++ /dev/null @@ -1,176 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::BelongsToReflection - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::BelongsToReflection - - - Private -

- -
- -
Inherits:
-
- SingularReflection - - - show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model/serializer/belongs_to_reflection.rb
- -
-
- -
-
-

- This class is part of a private API. - You should avoid using this class if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - - -

Instance Attribute Summary

- -

Attributes inherited from Field

-

#block, #name, #options

- - - - - - - - - - - - - - - -

Method Summary

- -

Methods inherited from Reflection

-

#build_association, #include_data, #initialize, #link, #meta, #value

- - - - - - - -
-

Constructor Details

- -

This class inherits a constructor from ActiveModel::Serializer::Reflection

- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Caching.html b/ActiveModel/Serializer/Caching.html deleted file mode 100644 index 4ded431a..00000000 --- a/ActiveModel/Serializer/Caching.html +++ /dev/null @@ -1,638 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Caching - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Caching - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Concern
- - - - - - -
Included in:
-
ActiveModel::Serializer
- - - -
Defined in:
-
lib/active_model/serializer/caching.rb
- -
-
- -

Defined Under Namespace

-

- - - Modules: ClassMethods - - - - -

- -

Constant Summary

- -
- -
CALLER_FILE = -
-
- -

Matches

- -
"c:/git/emberjs/ember-crm-backend/app/serializers/lead_serializer.rb:1:in `<top (required)>'"
-AND
-"/c/git/emberjs/ember-crm-backend/app/serializers/lead_serializer.rb:1:in `<top (required)>'"
-AS
-c/git/emberjs/ember-crm-backend/app/serializers/lead_serializer.rb
-
- - -
-
-
- - -
-
-
/
-  \A       # start of string
-  .+       # file path (one or more characters)
-  (?=      # stop previous match when
-    :\d+     # a colon is followed by one or more digits
-    :in      # followed by a colon followed by in
-  )
-/x
- -
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) cache_key(adapter_instance) - - - - - -

- - - - -
-
-
-
-256
-257
-258
-259
-260
-261
-262
-263
-264
-
-
# File 'lib/active_model/serializer/caching.rb', line 256
-
-def cache_key(adapter_instance)
-  return @cache_key if defined?(@cache_key)
-
-  parts = []
-  parts << object_cache_key
-  parts << adapter_instance.cache_key
-  parts << serializer_class._cache_digest unless serializer_class._skip_digest?
-  @cache_key = parts.join('/')
-end
-
-
- -
-

- - - (Object) fetch(adapter_instance, cache_options = serializer_class._cache_options) - - - - - -

- - - - -
-
-
-
-220
-221
-222
-223
-224
-225
-226
-227
-228
-
-
# File 'lib/active_model/serializer/caching.rb', line 220
-
-def fetch(adapter_instance, cache_options = serializer_class._cache_options)
-  if serializer_class.cache_store
-    serializer_class.cache_store.fetch(cache_key(adapter_instance), cache_options) do
-      yield
-    end
-  else
-    yield
-  end
-end
-
-
- -
-

- - - (Object) fetch_attributes(fields, cached_attributes, adapter_instance) - - - - - -

-
- -

INSTANCE METHODS

- - -
-
-
- - -
- - - - -
-
-
-
-205
-206
-207
-208
-209
-210
-211
-212
-213
-214
-215
-216
-217
-218
-
-
# File 'lib/active_model/serializer/caching.rb', line 205
-
-def fetch_attributes(fields, cached_attributes, adapter_instance)
-  if serializer_class.cache_enabled?
-    key = cache_key(adapter_instance)
-    cached_attributes.fetch(key) do
-      serializer_class.cache_store.fetch(key, serializer_class._cache_options) do
-        attributes(fields, true)
-      end
-    end
-  elsif serializer_class.fragment_cache_enabled?
-    fetch_attributes_fragment(adapter_instance)
-  else
-    attributes(fields, true)
-  end
-end
-
-
- -
-

- - - (Object) fetch_attributes_fragment(adapter_instance) - - - - - -

-
-
  1. -

    Determine cached fields from serializer class options

    -
  2. -

    Get non_cached_fields and fetch cache_fields

    -
  3. -

    Merge the two hashes using adapter_instance#fragment_cache

    -
- - -
-
-
- - -
- - - - -
-
-
-
-233
-234
-235
-236
-237
-238
-239
-240
-241
-242
-243
-244
-245
-246
-247
-248
-249
-250
-251
-252
-253
-254
-
-
# File 'lib/active_model/serializer/caching.rb', line 233
-
-def fetch_attributes_fragment(adapter_instance)
-  serializer_class._cache_options ||= {}
-  serializer_class._cache_options[:key] = serializer_class._cache_key if serializer_class._cache_key
-  fields = serializer_class.fragmented_attributes
-
-  non_cached_fields = fields[:non_cached].dup
-  non_cached_hash = attributes(non_cached_fields, true)
-  include_directive = JSONAPI::IncludeDirective.new(non_cached_fields - non_cached_hash.keys)
-  non_cached_hash.merge! resource_relationships({}, { include_directive: include_directive }, adapter_instance)
-
-  cached_fields = fields[:cached].dup
-  key = cache_key(adapter_instance)
-  cached_hash =
-    serializer_class.cache_store.fetch(key, serializer_class._cache_options) do
-      hash = attributes(cached_fields, true)
-      include_directive = JSONAPI::IncludeDirective.new(cached_fields - hash.keys)
-      hash.merge! resource_relationships({}, { include_directive: include_directive }, adapter_instance)
-    end
-
-  # Merge both results
-  adapter_instance.fragment_cache(cached_hash, non_cached_hash)
-end
-
-
- -
-

- - - (Object) object_cache_key - - - - - -

-
- -

Use object's cache_key if available, else derive a key from the object -Pass the `key` option to the `cache` declaration or override this method to -customize the cache key

- - -
-
-
- - -
- - - - -
-
-
-
-268
-269
-270
-271
-272
-273
-274
-275
-276
-277
-278
-
-
# File 'lib/active_model/serializer/caching.rb', line 268
-
-def object_cache_key
-  if object.respond_to?(:cache_key)
-    object.cache_key
-  elsif (serializer_cache_key = (serializer_class._cache_key || serializer_class._cache_options[:key]))
-    object_time_safe = object.updated_at
-    object_time_safe = object_time_safe.strftime('%Y%m%d%H%M%S%9N') if object_time_safe.respond_to?(:strftime)
-    "#{serializer_cache_key}/#{object.id}-#{object_time_safe}"
-  else
-    fail UndefinedCacheKey, "#{object.class} must define #cache_key, or the 'key:' option must be passed into '#{serializer_class}.cache'"
-  end
-end
-
-
- -
-

- - - (Object) serializer_class - - - - - -

- - - - -
-
-
-
-280
-281
-282
-
-
# File 'lib/active_model/serializer/caching.rb', line 280
-
-def serializer_class
-  @serializer_class ||= self.class
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Caching/ClassMethods.html b/ActiveModel/Serializer/Caching/ClassMethods.html deleted file mode 100644 index 93fcaad4..00000000 --- a/ActiveModel/Serializer/Caching/ClassMethods.html +++ /dev/null @@ -1,1300 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Caching::ClassMethods - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Caching::ClassMethods - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model/serializer/caching.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) _cache_digest - - - - - -

- - - - -
-
-
-
-48
-49
-50
-51
-
-
# File 'lib/active_model/serializer/caching.rb', line 48
-
-def _cache_digest
-  return @_cache_digest if defined?(@_cache_digest)
-  @_cache_digest = digest_caller_file(_cache_digest_file_path)
-end
-
-
- -
-

- - - (Boolean) _skip_digest? - - - - - -

-
- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-67
-68
-69
-
-
# File 'lib/active_model/serializer/caching.rb', line 67
-
-def _skip_digest?
-  _cache_options && _cache_options[:skip_digest]
-end
-
-
- -
-

- - - (Object) cache(options = {}) - - - - - -

-
- -
- TODO: -
-

require less code comments. See

-
-
- - -

Enables a serializer to be automatically cached

- -

Sets ::_cache object to -ActionController::Base.cache_store

- -
when Rails.configuration.action_controller.perform_caching
- -

github.com/rails-api/active_model_serializers/pull/1249#issuecomment-146567837

- - -
-
-
- -
-

Examples:

- - -
class PostSerializer < ActiveModel::Serializer
-  cache key: 'post', expires_in: 3.hours
-  attributes :title, :body
-
-  has_many :comments
-end
- -
-

Parameters:

-
    - -
  • - - options - - - (Hash) - - - (defaults to: {}) - - - — -
    -

    with valid keys: cache_store : @see ::_cache key : @see -::_cache_key only : @see ::_cache_only except : @see -::_cache_except skip_digest : does not include digest in cache_key all -else : @see ::_cache_options

    -
    - -
  • - -
- - -
- - - - -
-
-
-
-105
-106
-107
-108
-109
-110
-111
-112
-113
-114
-
-
# File 'lib/active_model/serializer/caching.rb', line 105
-
-def cache(options = {})
-  self._cache =
-    options.delete(:cache_store) ||
-    ActiveModelSerializers.config.cache_store ||
-    ActiveSupport::Cache.lookup_store(:null_store)
-  self._cache_key = options.delete(:key)
-  self._cache_only = options.delete(:only)
-  self._cache_except = options.delete(:except)
-  self._cache_options = options.empty? ? nil : options
-end
-
-
- -
-

- - - (Boolean) cache_enabled? - - - - - -

-
- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-150
-151
-152
-
-
# File 'lib/active_model/serializer/caching.rb', line 150
-
-def cache_enabled?
-  perform_caching? && cache_store && !_cache_only && !_cache_except
-end
-
-
- -
-

- - - (Hash) cache_read_multi(collection_serializer, adapter_instance, include_directive) - - - - - -

-
- -

Read cache from cache_store

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Hash) - - - -
  • - -
- -
- - - - -
-
-
-
-161
-162
-163
-164
-165
-166
-167
-168
-169
-
-
# File 'lib/active_model/serializer/caching.rb', line 161
-
-def cache_read_multi(collection_serializer, adapter_instance, include_directive)
-  return {} if ActiveModelSerializers.config.cache_store.blank?
-
-  keys = object_cache_keys(collection_serializer, adapter_instance, include_directive)
-
-  return {} if keys.blank?
-
-  ActiveModelSerializers.config.cache_store.read_multi(*keys)
-end
-
-
- -
-

- - - (nil, ...) cache_store - - - - - -

-
- -

The canonical method for getting the cache store for the serializer.

- - -
-
-
- -

Returns:

-
    - -
  • - - - (nil) - - - - — -
    -

    when _cache is not set (i.e. when `cache` has not been called)

    -
    - -
  • - -
  • - - - (._cache) - - - - — -
    -

    when _cache is not the NullStore

    -
    - -
  • - -
  • - - - (ActiveModelSerializers.config.cache_store) - - - - — -
    -

    when _cache is the NullStore. This is so we can use `cache` being called to -mean the serializer should be cached even if -ActiveModelSerializers.config.cache_store has not yet been set. That means -that when _cache is the NullStore and -ActiveModelSerializers.config.cache_store is configured, `cache_store` -becomes `ActiveModelSerializers.config.cache_store`.

    -
    - -
  • - -
  • - - - (nil) - - - - — -
    -

    when _cache is the NullStore and ActiveModelSerializers.config.cache_store -is nil.

    -
    - -
  • - -
- -
- - - - -
-
-
-
-140
-141
-142
-143
-144
-145
-146
-147
-148
-
-
# File 'lib/active_model/serializer/caching.rb', line 140
-
-def cache_store
-  return nil if _cache.nil?
-  return _cache if _cache.class != ActiveSupport::Cache::NullStore
-  if ActiveModelSerializers.config.cache_store
-    self._cache = ActiveModelSerializers.config.cache_store
-  else
-    nil
-  end
-end
-
-
- -
-

- - - (Object) digest_caller_file(caller_line) - - - - - -

-
- -

Hashes contents of file for _cache_digest

- - -
-
-
- - -
- - - - -
-
-
-
-54
-55
-56
-57
-58
-59
-60
-61
-62
-63
-64
-65
-
-
# File 'lib/active_model/serializer/caching.rb', line 54
-
-def digest_caller_file(caller_line)
-  serializer_file_path = caller_line[CALLER_FILE]
-  serializer_file_contents = IO.read(serializer_file_path)
-  Digest::MD5.hexdigest(serializer_file_contents)
-rescue TypeError, Errno::ENOENT
-  warn <<-EOF.strip_heredoc
-    Cannot digest non-existent file: '#{caller_line}'.
-    Please set `::_cache_digest` of the serializer
-    if you'd like to cache it.
-    EOF
-  ''.freeze
-end
-
-
- -
-

- - - (Boolean) fragment_cache_enabled? - - - - - -

-
- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-154
-155
-156
-157
-
-
# File 'lib/active_model/serializer/caching.rb', line 154
-
-def fragment_cache_enabled?
-  perform_caching? && cache_store &&
-    (_cache_only && !_cache_except || !_cache_only && _cache_except)
-end
-
-
- -
-

- - - (Object) fragmented_attributes - - - - - -

- - - - -
-
-
-
-71
-72
-73
-74
-75
-76
-77
-78
-79
-80
-
-
# File 'lib/active_model/serializer/caching.rb', line 71
-
-def fragmented_attributes
-  cached = _cache_only ? _cache_only : _attributes - _cache_except
-  cached = cached.map! { |field| _attributes_keys.fetch(field, field) }
-  non_cached = _attributes - cached
-  non_cached = non_cached.map! { |field| _attributes_keys.fetch(field, field) }
-  {
-    cached: cached,
-    non_cached: non_cached
-  }
-end
-
-
- -
-

- - - (Object) inherited(base) - - - - - -

- - - - -
-
-
-
-42
-43
-44
-45
-46
-
-
# File 'lib/active_model/serializer/caching.rb', line 42
-
-def inherited(base)
-  super
-  caller_line = caller[1]
-  base._cache_digest_file_path = caller_line
-end
-
-
- -
-

- - - (String?) object_cache_key(serializer, adapter_instance) - - - - - -

-
- -

Returns the cache_key of the serializer or nil

- - -
-
-
- -

Returns:

-
    - -
  • - - - (String, nil) - - - - — -
    -

    the cache_key of the serializer or nil

    -
    - -
  • - -
- -
- - - - -
-
-
-
-197
-198
-199
-200
-201
-
-
# File 'lib/active_model/serializer/caching.rb', line 197
-
-def object_cache_key(serializer, adapter_instance)
-  return unless serializer.present? && serializer.object.present?
-
-  serializer.class.cache_enabled? ? serializer.cache_key(adapter_instance) : nil
-end
-
-
- -
-

- - - (Array) object_cache_keys(collection_serializer, adapter_instance, include_directive) - - - - - -

-
- -

Find all cache_key for the collection_serializer

- - -
-
-
-

Parameters:

- - -

Returns:

-
    - -
  • - - - (Array) - - - - — -
    -

    all cache_key of collection_serializer

    -
    - -
  • - -
- -
- - - - -
-
-
-
-176
-177
-178
-179
-180
-181
-182
-183
-184
-185
-186
-187
-188
-189
-190
-191
-192
-193
-194
-
-
# File 'lib/active_model/serializer/caching.rb', line 176
-
-def object_cache_keys(collection_serializer, adapter_instance, include_directive)
-  cache_keys = []
-
-  collection_serializer.each do |serializer|
-    cache_keys << object_cache_key(serializer, adapter_instance)
-
-    serializer.associations(include_directive).each do |association|
-      if association.serializer.respond_to?(:each)
-        association.serializer.each do |sub_serializer|
-          cache_keys << object_cache_key(sub_serializer, adapter_instance)
-        end
-      else
-        cache_keys << object_cache_key(association.serializer, adapter_instance)
-      end
-    end
-  end
-
-  cache_keys.compact.uniq
-end
-
-
- -
-

- - - (true, false) perform_caching - - - - Also known as: - perform_caching? - - - - -

-
- -

Value is from ActiveModelSerializers.config.perform_caching. Is used to -globally enable or disable all serializer caching, just like -Rails.configuration.action_controller.perform_caching, which is its default -value in a Rails application. Memoizes value of config first time it is -called with a non-nil value. rubocop:disable Style/ClassVars

- - -
-
-
- -

Returns:

-
    - -
  • - - - (true, false) - - - -
  • - -
- -
- - - - -
-
-
-
-123
-124
-125
-126
-
-
# File 'lib/active_model/serializer/caching.rb', line 123
-
-def perform_caching
-  return @@perform_caching if defined?(@@perform_caching) && !@@perform_caching.nil?
-  @@perform_caching = ActiveModelSerializers.config.perform_caching
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/CollectionReflection.html b/ActiveModel/Serializer/CollectionReflection.html deleted file mode 100644 index 0a6312c4..00000000 --- a/ActiveModel/Serializer/CollectionReflection.html +++ /dev/null @@ -1,172 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::CollectionReflection - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::CollectionReflection - - - Private -

- -
- -
Inherits:
-
- Reflection - -
    -
  • Object
  • - - - - - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model/serializer/collection_reflection.rb
- -
-
- -
-
-

- This class is part of a private API. - You should avoid using this class if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
-

Direct Known Subclasses

-

HasManyReflection

-
- - - - - - -

Instance Attribute Summary

- -

Attributes inherited from Field

-

#block, #name, #options

- - - - - - - - - -

Method Summary

- -

Methods inherited from Reflection

-

#build_association, #include_data, #initialize, #link, #meta, #value

- - - - - - - -
-

Constructor Details

- -

This class inherits a constructor from ActiveModel::Serializer::Reflection

- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/CollectionSerializer.html b/ActiveModel/Serializer/CollectionSerializer.html deleted file mode 100644 index b0d2cd15..00000000 --- a/ActiveModel/Serializer/CollectionSerializer.html +++ /dev/null @@ -1,712 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::CollectionSerializer - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::CollectionSerializer - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - -
Includes:
-
Enumerable
- - - - - -
Defined in:
-
lib/active_model/serializer/collection_serializer.rb
- -
-
- -
-

Direct Known Subclasses

-

ArraySerializer

-
- -

Constant Summary

- -
- -
NoSerializerError = - -
-
Class.new(StandardError)
- -
- - - - - -

Instance Attribute Summary (collapse)

- - - - - - -

- Instance Method Summary - (collapse) -

- - - - - -
-

Constructor Details

- -
-

- - - (CollectionSerializer) initialize(resources, options = {}) - - - - - -

-
- -

Returns a new instance of CollectionSerializer

- - -
-
-
- - -
- - - - -
-
-
-
-10
-11
-12
-13
-14
-15
-
-
# File 'lib/active_model/serializer/collection_serializer.rb', line 10
-
-def initialize(resources, options = {})
-  @object                  = resources
-  @options                 = options
-  @root                    = options[:root]
-  @serializers             = serializers_from_resources
-end
-
-
- -
- -
-

Instance Attribute Details

- - - -
-

- - - (Object) object (readonly) - - - - - -

-
- -

Returns the value of attribute object

- - -
-
-
- - -
- - - - -
-
-
-
-8
-9
-10
-
-
# File 'lib/active_model/serializer/collection_serializer.rb', line 8
-
-def object
-  @object
-end
-
-
- - - -
-

- - - (Object) root (readonly) - - - - - -

-
- -

Returns the value of attribute root

- - -
-
-
- - -
- - - - -
-
-
-
-8
-9
-10
-
-
# File 'lib/active_model/serializer/collection_serializer.rb', line 8
-
-def root
-  @root
-end
-
-
- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) json_key - - - - - -

-
- -

TODO: unify naming of root, json_key, and _type. Right now, a -serializer's json_key comes from the root option or the object's -model name, by default. But, if a dev defines a custom `json_key` method -with an explicit value, we have no simple way to know that it is safe to -call that instance method. (which is really a class property at this point, -anyhow). rubocop:disable Metrics/CyclomaticComplexity Disabling cop since -it's good to highlight the complexity of this method by including all -the logic right here.

- - -
-
-
- - -
- - - - -
-
-
-
-39
-40
-41
-42
-43
-44
-45
-46
-47
-48
-49
-50
-51
-
-
# File 'lib/active_model/serializer/collection_serializer.rb', line 39
-
-def json_key
-  return root if root
-  # 1. get from options[:serializer] for empty resource collection
-  key = object.empty? &&
-    (explicit_serializer_class = options[:serializer]) &&
-    explicit_serializer_class._type
-  # 2. get from first serializer instance in collection
-  key ||= (serializer = serializers.first) && serializer.json_key
-  # 3. get from collection name, if a named collection
-  key ||= object.respond_to?(:name) ? object.name && object.name.underscore : nil
-  # 4. key may be nil for empty collection and no serializer option
-  key && key.pluralize
-end
-
-
- -
-

- - - (Boolean) paginated? - - - - - -

-
- -

rubocop:enable Metrics/CyclomaticComplexity

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-54
-55
-56
-57
-58
-
-
# File 'lib/active_model/serializer/collection_serializer.rb', line 54
-
-def paginated?
-  object.respond_to?(:current_page) &&
-    object.respond_to?(:total_pages) &&
-    object.respond_to?(:size)
-end
-
-
- -
-

- - - (Object) serializable_hash(adapter_options, options, adapter_instance) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - -
-
-
-
-22
-23
-24
-25
-26
-27
-28
-29
-
-
# File 'lib/active_model/serializer/collection_serializer.rb', line 22
-
-def serializable_hash(adapter_options, options, adapter_instance)
-  include_directive = ActiveModel::Serializer.include_directive_from_options(adapter_options)
-  adapter_options[:cached_attributes] ||= ActiveModel::Serializer.cache_read_multi(self, adapter_instance, include_directive)
-  adapter_opts = adapter_options.merge(include_directive: include_directive)
-  serializers.map do |serializer|
-    serializer.serializable_hash(adapter_opts, options, adapter_instance)
-  end
-end
-
-
- -
-

- - - (Boolean) success? - - - - - -

-
- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-17
-18
-19
-
-
# File 'lib/active_model/serializer/collection_serializer.rb', line 17
-
-def success?
-  true
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Configuration.html b/ActiveModel/Serializer/Configuration.html deleted file mode 100644 index 0a7072e1..00000000 --- a/ActiveModel/Serializer/Configuration.html +++ /dev/null @@ -1,119 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Configuration - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Configuration - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Concern
- - - - -
Includes:
-
ActiveSupport::Configurable
- - - - -
Included in:
-
ActiveModel::Serializer
- - - -
Defined in:
-
lib/active_model/serializer/configuration.rb
- -
-
- - - - - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/ErrorSerializer.html b/ActiveModel/Serializer/ErrorSerializer.html deleted file mode 100644 index d8e76464..00000000 --- a/ActiveModel/Serializer/ErrorSerializer.html +++ /dev/null @@ -1,396 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::ErrorSerializer - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::ErrorSerializer - - - -

- -
- -
Inherits:
-
- ActiveModel::Serializer - - - show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model/serializer/error_serializer.rb
- -
-
- - -

Constant Summary

- - - - -

Constant Summary

- -

Constants inherited - from ActiveModel::Serializer

-

SERIALIZABLE_HASH_VALID_KEYS, UndefinedCacheKey, VERSION

- - - -

Constants included - from Caching

-

Caching::CALLER_FILE

- - - - -

Instance Attribute Summary

- -

Attributes inherited from ActiveModel::Serializer

-

#object, #root, #scope

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods inherited from ActiveModel::Serializer

-

adapter, get_serializer_for, include_directive_from_options, #initialize, #json_key, #read_attribute_for_serialization, #relationship_value_for, #resource_relationships, #serializable_hash, serialization_adapter_instance, serializer_for, serializer_lookup_chain_for, serializers_cache

- - - - - - - - - -

Methods included from ActiveModelSerializers::Deprecate

-

delegate_and_deprecate, deprecate

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

Methods included from Caching

-

#cache_key, #fetch, #fetch_attributes, #fetch_attributes_fragment, #object_cache_key, #serializer_class

- - - - - - - - - - - - - - - - - -

Methods included from Associations

-

#associations

- - - - - - - - - -
-

Constructor Details

- -

This class inherits a constructor from ActiveModel::Serializer

- -
- - -
-

Instance Method Details

- - -
-

- - - (Hash<field_name,Array<error_message>>) as_json - - - - - -

-
- - -
-
-
- -

Returns:

-
    - -
  • - - - (Hash<field_name,Array<error_message>>) - - - -
  • - -
- -
- - - - -
-
-
-
-3
-4
-5
-
-
# File 'lib/active_model/serializer/error_serializer.rb', line 3
-
-def as_json
-  object.errors.messages
-end
-
-
- -
-

- - - (Boolean) success? - - - - - -

-
- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-7
-8
-9
-
-
# File 'lib/active_model/serializer/error_serializer.rb', line 7
-
-def success?
-  false
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/ErrorsSerializer.html b/ActiveModel/Serializer/ErrorsSerializer.html deleted file mode 100644 index b8db05b6..00000000 --- a/ActiveModel/Serializer/ErrorsSerializer.html +++ /dev/null @@ -1,503 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::ErrorsSerializer - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::ErrorsSerializer - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - -
Includes:
-
Enumerable
- - - - - -
Defined in:
-
lib/active_model/serializer/errors_serializer.rb
- -
-
- - - - - -

Instance Attribute Summary (collapse)

- - - - - - -

- Instance Method Summary - (collapse) -

- - - - - -
-

Constructor Details

- -
-

- - - (ErrorsSerializer) initialize(resources, options = {}) - - - - - -

-
- -

Returns a new instance of ErrorsSerializer

- - -
-
-
- - -
- - - - -
-
-
-
-7
-8
-9
-10
-11
-12
-13
-14
-
-
# File 'lib/active_model/serializer/errors_serializer.rb', line 7
-
-def initialize(resources, options = {})
-  @root = options[:root]
-  @object = resources
-  @serializers = resources.map do |resource|
-    serializer_class = options.fetch(:serializer) { ActiveModel::Serializer::ErrorSerializer }
-    serializer_class.new(resource, options.except(:serializer))
-  end
-end
-
-
- -
- -
-

Instance Attribute Details

- - - -
-

- - - (Object) object (readonly) - - - - - -

-
- -

Returns the value of attribute object

- - -
-
-
- - -
- - - - -
-
-
-
-5
-6
-7
-
-
# File 'lib/active_model/serializer/errors_serializer.rb', line 5
-
-def object
-  @object
-end
-
-
- - - -
-

- - - (Object) root (readonly) - - - - - -

-
- -

Returns the value of attribute root

- - -
-
-
- - -
- - - - -
-
-
-
-5
-6
-7
-
-
# File 'lib/active_model/serializer/errors_serializer.rb', line 5
-
-def root
-  @root
-end
-
-
- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) json_key - - - - - -

- - - - -
-
-
-
-20
-21
-22
-
-
# File 'lib/active_model/serializer/errors_serializer.rb', line 20
-
-def json_key
-  nil
-end
-
-
- -
-

- - - (Boolean) success? - - - - - -

-
- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-16
-17
-18
-
-
# File 'lib/active_model/serializer/errors_serializer.rb', line 16
-
-def success?
-  false
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Field.html b/ActiveModel/Serializer/Field.html deleted file mode 100644 index 3c1c34d6..00000000 --- a/ActiveModel/Serializer/Field.html +++ /dev/null @@ -1,414 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::Field - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::Field - - - -

- -
- -
Inherits:
-
- Struct - -
    -
  • Object
  • - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model/serializer/field.rb
- -
-
- -

Overview

-
- -

Holds all the meta-data about a field (i.e. attribute or association) as it -was specified in the ActiveModel::Serializer class. Notice that the field -block is evaluated in the context of the serializer.

- - -
-
-
- - -
-

Direct Known Subclasses

-

Attribute, Reflection

-
- - - - -

Instance Attribute Summary (collapse)

- - - - - - - -
-

Instance Attribute Details

- - - -
-

- - - (Object) block - - - - - -

-
- -

Returns the value of attribute block

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Object) - - - - — -
    -

    the current value of block

    -
    - -
  • - -
- -
- - - - -
-
-
-
-6
-7
-8
-
-
# File 'lib/active_model/serializer/field.rb', line 6
-
-def block
-  @block
-end
-
-
- - - -
-

- - - (Object) name - - - - - -

-
- -

Returns the value of attribute name

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Object) - - - - — -
    -

    the current value of name

    -
    - -
  • - -
- -
- - - - -
-
-
-
-6
-7
-8
-
-
# File 'lib/active_model/serializer/field.rb', line 6
-
-def name
-  @name
-end
-
-
- - - -
-

- - - (Object) options - - - - - -

-
- -

Returns the value of attribute options

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Object) - - - - — -
    -

    the current value of options

    -
    - -
  • - -
- -
- - - - -
-
-
-
-6
-7
-8
-
-
# File 'lib/active_model/serializer/field.rb', line 6
-
-def options
-  @options
-end
-
-
- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Fieldset.html b/ActiveModel/Serializer/Fieldset.html deleted file mode 100644 index 386148f6..00000000 --- a/ActiveModel/Serializer/Fieldset.html +++ /dev/null @@ -1,312 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::Fieldset - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::Fieldset - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model/serializer/fieldset.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - -
-

Constructor Details

- -
-

- - - (Fieldset) initialize(fields) - - - - - -

-
- -

Returns a new instance of Fieldset

- - -
-
-
- - -
- - - - -
-
-
-
-4
-5
-6
-
-
# File 'lib/active_model/serializer/fieldset.rb', line 4
-
-def initialize(fields)
-  @raw_fields = fields || {}
-end
-
-
- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) fields - - - - - -

- - - - -
-
-
-
-8
-9
-10
-
-
# File 'lib/active_model/serializer/fieldset.rb', line 8
-
-def fields
-  @fields ||= parsed_fields
-end
-
-
- -
-

- - - (Object) fields_for(type) - - - - - -

- - - - -
-
-
-
-12
-13
-14
-
-
# File 'lib/active_model/serializer/fieldset.rb', line 12
-
-def fields_for(type)
-  fields[type.singularize.to_sym] || fields[type.pluralize.to_sym]
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/HasManyReflection.html b/ActiveModel/Serializer/HasManyReflection.html deleted file mode 100644 index 976209d2..00000000 --- a/ActiveModel/Serializer/HasManyReflection.html +++ /dev/null @@ -1,176 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::HasManyReflection - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::HasManyReflection - - - Private -

- -
- -
Inherits:
-
- CollectionReflection - - - show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model/serializer/has_many_reflection.rb
- -
-
- -
-
-

- This class is part of a private API. - You should avoid using this class if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - - -

Instance Attribute Summary

- -

Attributes inherited from Field

-

#block, #name, #options

- - - - - - - - - - - - - - - -

Method Summary

- -

Methods inherited from Reflection

-

#build_association, #include_data, #initialize, #link, #meta, #value

- - - - - - - -
-

Constructor Details

- -

This class inherits a constructor from ActiveModel::Serializer::Reflection

- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/HasOneReflection.html b/ActiveModel/Serializer/HasOneReflection.html deleted file mode 100644 index e89fe677..00000000 --- a/ActiveModel/Serializer/HasOneReflection.html +++ /dev/null @@ -1,176 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::HasOneReflection - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::HasOneReflection - - - Private -

- -
- -
Inherits:
-
- SingularReflection - - - show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model/serializer/has_one_reflection.rb
- -
-
- -
-
-

- This class is part of a private API. - You should avoid using this class if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - - -

Instance Attribute Summary

- -

Attributes inherited from Field

-

#block, #name, #options

- - - - - - - - - - - - - - - -

Method Summary

- -

Methods inherited from Reflection

-

#build_association, #include_data, #initialize, #link, #meta, #value

- - - - - - - -
-

Constructor Details

- -

This class inherits a constructor from ActiveModel::Serializer::Reflection

- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Links.html b/ActiveModel/Serializer/Links.html deleted file mode 100644 index 99958424..00000000 --- a/ActiveModel/Serializer/Links.html +++ /dev/null @@ -1,124 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Links - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Links - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Concern
- - - - - - -
Included in:
-
ActiveModel::Serializer
- - - -
Defined in:
-
lib/active_model/serializer/links.rb
- -
-
- -

Defined Under Namespace

-

- - - Modules: ClassMethods - - - - -

- - - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Links/ClassMethods.html b/ActiveModel/Serializer/Links/ClassMethods.html deleted file mode 100644 index 9bb7fba6..00000000 --- a/ActiveModel/Serializer/Links/ClassMethods.html +++ /dev/null @@ -1,255 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Links::ClassMethods - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Links::ClassMethods - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model/serializer/links.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) inherited(base) - - - - - -

- - - - -
-
-
-
-16
-17
-18
-19
-
-
# File 'lib/active_model/serializer/links.rb', line 16
-
-def inherited(base)
-  super
-  base._links = _links.dup
-end
-
-
- -
-
-
- -

Define a link on a serializer.

- - -
-
-
- -
-

Examples:

- - -
link(:self) { resource_url(object) }
- - -
link(:self) { "http://example.com/resource/#{object.id}" }
- - -
link :resource, "http://example.com/resource"
- -
- - -
- - - - -
-
-
-
-29
-30
-31
-
-
# File 'lib/active_model/serializer/links.rb', line 29
-
-def link(name, value = nil, &block)
-  _links[name] = block || value
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Lint.html b/ActiveModel/Serializer/Lint.html deleted file mode 100644 index 03ec8768..00000000 --- a/ActiveModel/Serializer/Lint.html +++ /dev/null @@ -1,115 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Lint - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Lint - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model/serializer/lint.rb
- -
-
- -

Defined Under Namespace

-

- - - Modules: Tests - - - - -

- - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Lint/Tests.html b/ActiveModel/Serializer/Lint/Tests.html deleted file mode 100644 index 2e00fd65..00000000 --- a/ActiveModel/Serializer/Lint/Tests.html +++ /dev/null @@ -1,910 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Lint::Tests - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Lint::Tests - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model/serializer/lint.rb
- -
-
- -

Overview

-
- -

Active Model Serializer Lint Tests

- -

You can test whether an object is compliant with the Active Model -Serializers API by including -ActiveModel::Serializer::Lint::Tests in your TestCase. It will -include tests that tell you whether your object is fully compliant, or if -not, which aspects of the API are not implemented.

- -

Note an object is not required to implement all APIs in order to work with -Active Model Serializers. This module only intends to provide guidance in -case you want all features out of the box.

- -

These tests do not attempt to determine the semantic correctness of the -returned values. For instance, you could implement -serializable_hash to always return {}, and the tests would -pass. It is up to you to ensure that the values are semantically -meaningful.

- - -
-
-
- - -
- - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) test_active_model_errors - - - - - -

- - - - -
-
-
-
-122
-123
-124
-
-
# File 'lib/active_model/serializer/lint.rb', line 122
-
-def test_active_model_errors
-  assert_respond_to resource, :errors
-end
-
-
- -
-

- - - (Object) test_active_model_errors_human_attribute_name - - - - - -

- - - - -
-
-
-
-126
-127
-128
-129
-
-
# File 'lib/active_model/serializer/lint.rb', line 126
-
-def test_active_model_errors_human_attribute_name
-  assert_respond_to resource.class, :human_attribute_name
-  assert_equal(-2, resource.class.method(:human_attribute_name).arity)
-end
-
-
- -
-

- - - (Object) test_active_model_errors_lookup_ancestors - - - - - -

- - - - -
-
-
-
-131
-132
-133
-134
-
-
# File 'lib/active_model/serializer/lint.rb', line 131
-
-def test_active_model_errors_lookup_ancestors
-  assert_respond_to resource.class, :lookup_ancestors
-  assert_equal 0, resource.class.method(:lookup_ancestors).arity
-end
-
-
- -
-

- - - (Object) test_as_json - - - - - -

-
- -

Passes if the object responds to as_json and if it takes zero -or one arguments. Fails otherwise.

- -

as_json returns a hash representation of a serialized object. -It may delegate to serializable_hash Typically, it is -implemented either by including ActiveModel::Serialization which includes -ActiveModel::Serializers::JSON. or by the JSON gem when required.

- - -
-
-
- - -
- - - - -
-
-
-
-54
-55
-56
-57
-58
-
-
# File 'lib/active_model/serializer/lint.rb', line 54
-
-def test_as_json
-  assert_respond_to resource, :as_json
-  resource.as_json
-  resource.as_json(nil)
-end
-
-
- -
-

- - - (Object) test_cache_key - - - - - -

-
- -

Passes if the object responds to cache_key Fails otherwise.

- -

cache_key returns a (self-expiring) unique key for the object, -and is part of the (self-expiring) cache_key, which is used by the adapter. -It is not required unless caching is enabled.

- - -
-
-
- - -
- - - - -
-
-
-
-79
-80
-81
-82
-83
-
-
# File 'lib/active_model/serializer/lint.rb', line 79
-
-def test_cache_key
-  assert_respond_to resource, :cache_key
-  actual_arity = resource.method(:cache_key).arity
-  assert_includes [-1, 0], actual_arity, "expected #{actual_arity.inspect} to be 0 or -1"
-end
-
-
- -
-

- - - (Object) test_id - - - - - -

-
- -

Passes if the object responds to id and if it takes no -arguments. Fails otherwise.

- -

id returns a unique identifier for the object. It is not -required unless caching is enabled.

- - -
-
-
- - -
- - - - -
-
-
-
-104
-105
-106
-107
-
-
# File 'lib/active_model/serializer/lint.rb', line 104
-
-def test_id
-  assert_respond_to resource, :id
-  assert_equal 0, resource.method(:id).arity
-end
-
-
- -
-

- - - (Object) test_model_name - - - - - -

-
- -

Passes if the object's class responds to model_name and if -it is in an instance of ActiveModel::Name. Fails otherwise.

- -

model_name returns an ActiveModel::Name instance. It is used -by the serializer to identify the object's type. It is not required -unless caching is enabled.

- - -
-
-
- - -
- - - - -
-
-
-
-116
-117
-118
-119
-120
-
-
# File 'lib/active_model/serializer/lint.rb', line 116
-
-def test_model_name
-  resource_class = resource.class
-  assert_respond_to resource_class, :model_name
-  assert_instance_of resource_class.model_name, ActiveModel::Name
-end
-
-
- -
-

- - - (Object) test_read_attribute_for_serialization - - - - - -

-
- -

Passes if the object responds to -read_attribute_for_serialization and if it requires one -argument (the attribute to be read). Fails otherwise.

- -

read_attribute_for_serialization gets the attribute value for -serialization Typically, it is implemented by including -ActiveModel::Serialization.

- - -
-
-
- - -
- - - - -
-
-
-
-36
-37
-38
-39
-40
-41
-42
-43
-
-
# File 'lib/active_model/serializer/lint.rb', line 36
-
-def test_read_attribute_for_serialization
-  assert_respond_to resource, :read_attribute_for_serialization, 'The resource should respond to read_attribute_for_serialization'
-  actual_arity = resource.method(:read_attribute_for_serialization).arity
-  # using absolute value since arity is:
-  #  1 for def read_attribute_for_serialization(name); end
-  # -1 for alias :read_attribute_for_serialization :send
-  assert_equal 1, actual_arity.abs, "expected #{actual_arity.inspect}.abs to be 1 or -1"
-end
-
-
- -
-

- - - (Object) test_serializable_hash - - - - - -

-
- -

Passes if the object responds to serializable_hash and if it -takes zero or one arguments. Fails otherwise.

- -

serializable_hash returns a hash representation of a -object's attributes. Typically, it is implemented by including -ActiveModel::Serialization.

- - -
-
-
- - -
- - - - -
-
-
-
-24
-25
-26
-27
-28
-
-
# File 'lib/active_model/serializer/lint.rb', line 24
-
-def test_serializable_hash
-  assert_respond_to resource, :serializable_hash, 'The resource should respond to serializable_hash'
-  resource.serializable_hash
-  resource.serializable_hash(nil)
-end
-
-
- -
-

- - - (Object) test_to_json - - - - - -

-
- -

Passes if the object responds to to_json and if it takes zero -or one arguments. Fails otherwise.

- -

to_json returns a string representation (JSON) of a serialized -object. It may be called on the result of as_json. Typically, -it is implemented on all objects when the JSON gem is required.

- - -
-
-
- - -
- - - - -
-
-
-
-67
-68
-69
-70
-71
-
-
# File 'lib/active_model/serializer/lint.rb', line 67
-
-def test_to_json
-  assert_respond_to resource, :to_json
-  resource.to_json
-  resource.to_json(nil)
-end
-
-
- -
-

- - - (Object) test_updated_at - - - - - -

-
- -

Passes if the object responds to updated_at and if it takes no -arguments. Fails otherwise.

- -

updated_at returns a Time object or iso8601 string and is part -of the (self-expiring) cache_key, which is used by the adapter. It is not -required unless caching is enabled.

- - -
-
-
- - -
- - - - -
-
-
-
-92
-93
-94
-95
-96
-
-
# File 'lib/active_model/serializer/lint.rb', line 92
-
-def test_updated_at
-  assert_respond_to resource, :updated_at
-  actual_arity = resource.method(:updated_at).arity
-  assert_equal 0, actual_arity
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Meta.html b/ActiveModel/Serializer/Meta.html deleted file mode 100644 index 1df77d2c..00000000 --- a/ActiveModel/Serializer/Meta.html +++ /dev/null @@ -1,124 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Meta - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Meta - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Concern
- - - - - - -
Included in:
-
ActiveModel::Serializer
- - - -
Defined in:
-
lib/active_model/serializer/meta.rb
- -
-
- -

Defined Under Namespace

-

- - - Modules: ClassMethods - - - - -

- - - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Meta/ClassMethods.html b/ActiveModel/Serializer/Meta/ClassMethods.html deleted file mode 100644 index f9b5a1c8..00000000 --- a/ActiveModel/Serializer/Meta/ClassMethods.html +++ /dev/null @@ -1,201 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Meta::ClassMethods - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Meta::ClassMethods - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model/serializer/meta.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) meta(value = nil, &block) - - - - - -

-
- -

Set the JSON API meta attribute of a serializer.

- - -
-
-
- -
-

Examples:

- - -
class AdminAuthorSerializer < ActiveModel::Serializer
-  meta { stuff: 'value' }
- - -
meta do
-  { comment_count: object.comments.count }
-end
- -
- - -
- - - - -
-
-
-
-23
-24
-25
-
-
# File 'lib/active_model/serializer/meta.rb', line 23
-
-def meta(value = nil, &block)
-  self._meta = block || value
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Null.html b/ActiveModel/Serializer/Null.html deleted file mode 100644 index 2746bcf8..00000000 --- a/ActiveModel/Serializer/Null.html +++ /dev/null @@ -1,399 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::Null - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::Null - - - -

- -
- -
Inherits:
-
- ActiveModel::Serializer - - - show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model/serializer/null.rb
- -
-
- - -

Constant Summary

- - - - -

Constant Summary

- -

Constants inherited - from ActiveModel::Serializer

-

SERIALIZABLE_HASH_VALID_KEYS, UndefinedCacheKey, VERSION

- - - -

Constants included - from Caching

-

Caching::CALLER_FILE

- - - - -

Instance Attribute Summary

- -

Attributes inherited from ActiveModel::Serializer

-

#object, #root, #scope

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods inherited from ActiveModel::Serializer

-

adapter, #as_json, get_serializer_for, include_directive_from_options, #initialize, #json_key, #read_attribute_for_serialization, #relationship_value_for, #resource_relationships, serialization_adapter_instance, serializer_for, serializer_lookup_chain_for, serializers_cache, #success?

- - - - - - - - - -

Methods included from ActiveModelSerializers::Deprecate

-

delegate_and_deprecate, deprecate

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

Methods included from Caching

-

#cache_key, #fetch, #fetch_attributes, #fetch_attributes_fragment, #object_cache_key, #serializer_class

- - - - - - - - - - - - - - - - - - - - - - - -
-

Constructor Details

- -

This class inherits a constructor from ActiveModel::Serializer

- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) associations - - - - - -

- - - - -
-
-
-
-8
-9
-10
-
-
# File 'lib/active_model/serializer/null.rb', line 8
-
-def associations(*)
-  {}
-end
-
-
- -
-

- - - (Object) attributes - - - - - -

- - - - -
-
-
-
-4
-5
-6
-
-
# File 'lib/active_model/serializer/null.rb', line 4
-
-def attributes(*)
-  {}
-end
-
-
- -
-

- - - (Object) serializable_hash - - - - - -

- - - - -
-
-
-
-12
-13
-14
-
-
# File 'lib/active_model/serializer/null.rb', line 12
-
-def serializable_hash(*)
-  {}
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Reflection.html b/ActiveModel/Serializer/Reflection.html deleted file mode 100644 index 946ed317..00000000 --- a/ActiveModel/Serializer/Reflection.html +++ /dev/null @@ -1,738 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::Reflection - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::Reflection - - - -

- -
- -
Inherits:
-
- Field - -
    -
  • Object
  • - - - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model/serializer/reflection.rb
- -
-
- -

Overview

-
- -

Holds all the meta-data about an association as it was specified in the -ActiveModel::Serializer class.

- -
Specifically, the association 'comments' is evaluated two different ways:
-1) as 'comments' and named 'comments'.
-2) as 'object.comments.last(1)' and named 'last_comments'.
-
-PostSerializer._reflections #=>
-  # [
-  #   HasOneReflection.new(:author, serializer: AuthorSerializer),
-  #   HasManyReflection.new(:comments)
-  #   HasManyReflection.new(:comments, { key: :last_comments }, #<Block>)
-  #   HasManyReflection.new(:secret_meta_data, { if: :is_admin? })
-  # ]
- -

So you can inspect reflections in your Adapters.

- - -
-
-
- -
-

Examples:

- - -
class PostSerializer < ActiveModel::Serializer
-  has_one :author, serializer: AuthorSerializer
-  has_many :comments
-  has_many :comments, key: :last_comments do
-    object.comments.last(1)
-  end
-  has_many :secret_meta_data, if: :is_admin?
-
-  def is_admin?
-    current_user.admin?
-  end
-end
- -
- - -
-

Direct Known Subclasses

-

CollectionReflection, SingularReflection

-
- - - - - - -

Instance Attribute Summary

- -

Attributes inherited from Field

-

#block, #name, #options

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - -
-

Constructor Details

- -
-

- - - (Reflection) initialize - - - - - -

-
- -

Returns a new instance of Reflection

- - -
-
-
- - -
- - - - -
-
-
-
-37
-38
-39
-40
-41
-42
-
-
# File 'lib/active_model/serializer/reflection.rb', line 37
-
-def initialize(*)
-  super
-  @_links = {}
-  @_include_data = true
-  @_meta = nil
-end
-
-
- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) build_association(subject, parent_serializer_options) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- -

Build association. This method is used internally to build serializer's -association by its reflection.

- - -
-
-
- -
-

Examples:

- - -
# Given the following serializer defined:
-class PostSerializer < ActiveModel::Serializer
-  has_many :comments, serializer: CommentSummarySerializer
-end
-
-# Then you instantiate your serializer
-post_serializer = PostSerializer.new(post, foo: 'bar') #
-# to build association for comments you need to get reflection
-comments_reflection = PostSerializer._reflections.detect { |r| r.name == :comments }
-# and #build_association
-comments_reflection.build_association(post_serializer, foo: 'bar')
- -
-

Parameters:

-
    - -
  • - - subject - - - (Serializer) - - - - — -
    -

    is a parent serializer for given association

    -
    - -
  • - -
  • - - parent_serializer_options - - - (Hash{Symbol => Object}) - - - -
  • - -
- - -
- - - - -
-
-
-
-109
-110
-111
-112
-113
-114
-115
-116
-117
-118
-119
-120
-121
-122
-123
-124
-125
-126
-127
-128
-129
-
-
# File 'lib/active_model/serializer/reflection.rb', line 109
-
-def build_association(subject, parent_serializer_options)
-  association_value = value(subject)
-  reflection_options = options.dup
-  serializer_class = subject.class.serializer_for(association_value, reflection_options)
-  reflection_options[:include_data] = @_include_data
-
-  if serializer_class
-    begin
-      serializer = serializer_class.new(
-        association_value,
-        serializer_options(subject, parent_serializer_options, reflection_options)
-      )
-    rescue ActiveModel::Serializer::CollectionSerializer::NoSerializerError
-      reflection_options[:virtual_value] = association_value.try(:as_json) || association_value
-    end
-  elsif !association_value.nil? && !association_value.instance_of?(Object)
-    reflection_options[:virtual_value] = association_value
-  end
-
-  Association.new(name, serializer, reflection_options, @_links, @_meta)
-end
-
-
- -
-

- - - (Object) include_data(value = true) - - - - - -

- - - - -
-
-
-
-54
-55
-56
-57
-
-
# File 'lib/active_model/serializer/reflection.rb', line 54
-
-def include_data(value = true)
-  @_include_data = value
-  :nil
-end
-
-
- -
- - - - - -
-
-
-
-44
-45
-46
-47
-
-
# File 'lib/active_model/serializer/reflection.rb', line 44
-
-def link(name, value = nil, &block)
-  @_links[name] = block || value
-  :nil
-end
-
-
- -
-

- - - (Object) meta(value = nil, &block) - - - - - -

- - - - -
-
-
-
-49
-50
-51
-52
-
-
# File 'lib/active_model/serializer/reflection.rb', line 49
-
-def meta(value = nil, &block)
-  @_meta = block || value
-  :nil
-end
-
-
- -
-

- - - (:nil, associated resource or resource collection) value(serializer) {|ActiveModel::Serializer| ... } - - - - - -

-
- - -
-
-
- -
-

Examples:

- - -
has_one :blog do |serializer|
-  serializer.cached_blog
-end
-
-def cached_blog
-  cache_store.fetch("cached_blog:#{object.updated_at}") do
-    Blog.find(object.blog_id)
-  end
-end
- -
-

Parameters:

- - -

Yields:

- -

Returns:

-
    - -
  • - - - (:nil, associated resource or resource collection) - - - -
  • - -
- -
- - - - -
-
-
-
-72
-73
-74
-75
-76
-77
-78
-79
-80
-81
-82
-83
-84
-85
-86
-
-
# File 'lib/active_model/serializer/reflection.rb', line 72
-
-def value(serializer)
-  @object = serializer.object
-  @scope = serializer.scope
-
-  if block
-    block_value = instance_exec(serializer, &block)
-    if block_value != :nil
-      block_value
-    elsif @_include_data
-      serializer.read_attribute_for_serialization(name)
-    end
-  else
-    serializer.read_attribute_for_serialization(name)
-  end
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/SingularReflection.html b/ActiveModel/Serializer/SingularReflection.html deleted file mode 100644 index 98cf2944..00000000 --- a/ActiveModel/Serializer/SingularReflection.html +++ /dev/null @@ -1,172 +0,0 @@ - - - - - - Class: ActiveModel::Serializer::SingularReflection - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModel::Serializer::SingularReflection - - - Private -

- -
- -
Inherits:
-
- Reflection - -
    -
  • Object
  • - - - - - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model/serializer/singular_reflection.rb
- -
-
- -
-
-

- This class is part of a private API. - You should avoid using this class if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
-

Direct Known Subclasses

-

BelongsToReflection, HasOneReflection

-
- - - - - - -

Instance Attribute Summary

- -

Attributes inherited from Field

-

#block, #name, #options

- - - - - - - - - -

Method Summary

- -

Methods inherited from Reflection

-

#build_association, #include_data, #initialize, #link, #meta, #value

- - - - - - - -
-

Constructor Details

- -

This class inherits a constructor from ActiveModel::Serializer::Reflection

- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Type.html b/ActiveModel/Serializer/Type.html deleted file mode 100644 index 68c28833..00000000 --- a/ActiveModel/Serializer/Type.html +++ /dev/null @@ -1,124 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Type - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Type - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Concern
- - - - - - -
Included in:
-
ActiveModel::Serializer
- - - -
Defined in:
-
lib/active_model/serializer/type.rb
- -
-
- -

Defined Under Namespace

-

- - - Modules: ClassMethods - - - - -

- - - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/ActiveModel/Serializer/Type/ClassMethods.html b/ActiveModel/Serializer/Type/ClassMethods.html deleted file mode 100644 index 2efc47cb..00000000 --- a/ActiveModel/Serializer/Type/ClassMethods.html +++ /dev/null @@ -1,196 +0,0 @@ - - - - - - Module: ActiveModel::Serializer::Type::ClassMethods - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModel::Serializer::Type::ClassMethods - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model/serializer/type.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) type(type) - - - - - -

-
- -

Set the JSON API type of a serializer.

- - -
-
-
- -
-

Examples:

- - -
class AdminAuthorSerializer < ActiveModel::Serializer
-  type 'authors'
- -
- - -
- - - - -
-
-
-
-19
-20
-21
-
-
# File 'lib/active_model/serializer/type.rb', line 19
-
-def type(type)
-  self._type = type && type.to_s
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers.html b/ActiveModelSerializers.html deleted file mode 100644 index 086e06a8..00000000 --- a/ActiveModelSerializers.html +++ /dev/null @@ -1,462 +0,0 @@ - - - - - - Module: ActiveModelSerializers - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Autoload
- - - - - - - -
Defined in:
-
lib/active_model_serializers/model.rb,
- lib/active_model_serializers.rb,
lib/active_model_serializers/test.rb,
lib/active_model_serializers/railtie.rb,
lib/active_model_serializers/adapter.rb,
lib/active_model_serializers/logging.rb,
lib/active_model_serializers/deprecate.rb,
lib/active_model_serializers/callbacks.rb,
lib/active_model_serializers/test/schema.rb,
lib/active_model_serializers/adapter/null.rb,
lib/active_model_serializers/adapter/base.rb,
lib/active_model_serializers/json_pointer.rb,
lib/active_model_serializers/adapter/json.rb,
lib/active_model_serializers/key_transform.rb,
lib/active_model_serializers/test/serializer.rb,
lib/active_model_serializers/deserialization.rb,
lib/active_model_serializers/adapter/json_api.rb,
lib/active_model_serializers/adapter/attributes.rb,
lib/active_model_serializers/adapter/json_api/link.rb,
lib/active_model_serializers/serialization_context.rb,
lib/active_model_serializers/serializable_resource.rb,
lib/active_model_serializers/adapter/json_api/meta.rb,
lib/active_model_serializers/adapter/json_api/error.rb,
lib/active_model_serializers/adapter/json_api/jsonapi.rb,
lib/active_model_serializers/adapter/json_api/relationship.rb,
lib/active_model_serializers/adapter/json_api/deserialization.rb,
lib/active_model_serializers/adapter/json_api/pagination_links.rb,
lib/active_model_serializers/adapter/json_api/resource_identifier.rb
-
- -
-
- -

Overview

-
- -

JSON API specification rubocop:disable -Style/AsciiComments TODO: implement!

- -
 https://github.com/rails-api/active_model_serializers/issues/1235
- -

TODO: use uri_template in link generation?

- -
☐ https://github.com/rails-api/active_model_serializers/pull/1282#discussion_r42528812
-  see gem https://github.com/hannesg/uri_template
-  spec http://tools.ietf.org/html/rfc6570
-  impl https://developer.github.com/v3/#schema https://api.github.com/
- -

TODO: validate against a JSON schema document?

- -
 https://github.com/rails-api/active_model_serializers/issues/1162
- https://github.com/rails-api/active_model_serializers/pull/1270
- -

TODO: Routing

- -
 https://github.com/rails-api/active_model_serializers/pull/1476
- -

TODO: Query Params

- -
☑ `include` https://github.com/rails-api/active_model_serializers/pull/1131
-☑ `fields` https://github.com/rails-api/active_model_serializers/pull/700
-☑ `page[number]=3&page[size]=1` https://github.com/rails-api/active_model_serializers/pull/1041
-☐ `filter`
-☐ `sort`
- - -
-
-
- - -

Defined Under Namespace

-

- - - Modules: Adapter, Callbacks, Deprecate, Deserialization, JsonPointer, Jsonapi, KeyTransform, Logging, Test - - - - Classes: Model, Railtie, SerializableResource, SerializationContext - - -

- - - - -

Class Attribute Summary (collapse)

- - - - - - -

- Class Method Summary - (collapse) -

- - - - - - -
-

Class Attribute Details

- - - -
-

- - + (Object) logger - - - - - -

-
- -

Returns the value of attribute logger

- - -
-
-
- - -
- - - - -
-
-
-
-18
-19
-20
-
-
# File 'lib/active_model_serializers.rb', line 18
-
-def logger
-  @logger
-end
-
-
- -
- - -
-

Class Method Details

- - -
-

- - + (Object) config - - - - - -

- - - - -
-
-
-
-21
-22
-23
-
-
# File 'lib/active_model_serializers.rb', line 21
-
-def self.config
-  ActiveModel::Serializer.config
-end
-
-
- -
-

- - + (JSONAPI::IncludeDirective) default_include_directive - - - - - -

-
- -

Memoized default include directive

- - -
-
-
- -

Returns:

-
    - -
  • - - - (JSONAPI::IncludeDirective) - - - -
  • - -
- -
- - - - -
-
-
-
-36
-37
-38
-
-
# File 'lib/active_model_serializers.rb', line 36
-
-def self.default_include_directive
-  @default_include_directive ||= JSONAPI::IncludeDirective.new(config.default_includes, allow_wildcard: true)
-end
-
-
- -
-

- - + (Object) location_of_caller - - - - - -

-
- -

The file name and line number of the caller of the caller of this method.

- - -
-
-
- - -
- - - - -
-
-
-
-26
-27
-28
-29
-30
-31
-32
-
-
# File 'lib/active_model_serializers.rb', line 26
-
-def self.location_of_caller
-  caller[1] =~ /(.*?):(\d+).*?$/i
-  file = Regexp.last_match(1)
-  lineno = Regexp.last_match(2).to_i
-
-  [file, lineno]
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter.html b/ActiveModelSerializers/Adapter.html deleted file mode 100644 index eeada8eb..00000000 --- a/ActiveModelSerializers/Adapter.html +++ /dev/null @@ -1,887 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Adapter - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Adapter - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Autoload
- - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter.rb,
- lib/active_model_serializers/adapter/null.rb,
lib/active_model_serializers/adapter/base.rb,
lib/active_model_serializers/adapter/json.rb,
lib/active_model_serializers/adapter/json_api.rb,
lib/active_model_serializers/adapter/attributes.rb,
lib/active_model_serializers/adapter/json_api/link.rb,
lib/active_model_serializers/adapter/json_api/meta.rb,
lib/active_model_serializers/adapter/json_api/error.rb,
lib/active_model_serializers/adapter/json_api/jsonapi.rb,
lib/active_model_serializers/adapter/json_api/relationship.rb,
lib/active_model_serializers/adapter/json_api/deserialization.rb,
lib/active_model_serializers/adapter/json_api/pagination_links.rb,
lib/active_model_serializers/adapter/json_api/resource_identifier.rb
-
- -
-
- -

Defined Under Namespace

-

- - - - - Classes: Attributes, Base, Json, JsonApi, Null - - -

- -

Constant Summary

- -
- -
UnknownAdapterError = - -
-
Class.new(ArgumentError)
- -
- - - - - - - - - -

- Class Method Summary - (collapse) -

- - - - - - - -
-

Class Method Details

- - -
-

- - + (Object) adapter_class(adapter) - - - - - -

-
- - -
-
-
- - -

See Also:

- - -
- - - - -
-
-
-
-27
-28
-29
-
-
# File 'lib/active_model_serializers/adapter.rb', line 27
-
-def adapter_class(adapter)
-  ActiveModelSerializers::Adapter.lookup(adapter)
-end
-
-
- -
-

- - + (Hash<adapter_name, adapter_class>) adapter_map - - - - - -

-
- - -
-
-
- -

Returns:

- - -
- - - - -
-
-
-
-32
-33
-34
-
-
# File 'lib/active_model_serializers/adapter.rb', line 32
-
-def adapter_map
-  ADAPTER_MAP
-end
-
-
- -
-

- - + (Array<Symbol>) adapters - - - - - -

-
- -

Returns list of adapter names

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Array<Symbol>) - - - - — -
    -

    list of adapter names

    -
    - -
  • - -
- -
- - - - -
-
-
-
-37
-38
-39
-
-
# File 'lib/active_model_serializers/adapter.rb', line 37
-
-def adapters
-  adapter_map.keys.sort
-end
-
-
- -
-

- - + (Object) configured_adapter - - - - - -

-
- -

:nocov:

- - -
-
-
- - -
- - - - -
-
-
-
-16
-17
-18
-
-
# File 'lib/active_model_serializers/adapter.rb', line 16
-
-def configured_adapter
-  lookup(ActiveModelSerializers.config.adapter)
-end
-
-
- -
-

- - + (Object) create(resource, options = {}) - - - - - -

- - - - -
-
-
-
-20
-21
-22
-23
-24
-
-
# File 'lib/active_model_serializers/adapter.rb', line 20
-
-def create(resource, options = {})
-  override = options.delete(:adapter)
-  klass = override ? adapter_class(override) : configured_adapter
-  klass.new(resource, options)
-end
-
-
- -
-

- - + (ActiveModelSerializers::Adapter) lookup(adapter) - - - - - -

-
- -

Returns subclass of Adapter

- - -
-
-
-

Parameters:

-
    - -
  • - - adapter - - - (String, Symbol, Class) - - - - — -
    -

    name to fetch adapter by

    -
    - -
  • - -
- -

Returns:

- -

Raises:

- - -
- - - - -
-
-
-
-63
-64
-65
-66
-67
-68
-69
-70
-71
-72
-73
-74
-75
-76
-77
-78
-
-
# File 'lib/active_model_serializers/adapter.rb', line 63
-
-def lookup(adapter)
-  # 1. return if is a class
-  return adapter if adapter.is_a?(Class)
-  adapter_name = adapter.to_s.underscore
-  # 2. return if registered
-  adapter_map.fetch(adapter_name) do
-    # 3. try to find adapter class from environment
-    adapter_class = find_by_name(adapter_name)
-    register(adapter_name, adapter_class)
-    adapter_class
-  end
-rescue NameError, ArgumentError => e
-  failure_message =
-    "NameError: #{e.message}. Unknown adapter: #{adapter.inspect}. Valid adapters are: #{adapters}"
-  raise UnknownAdapterError, failure_message, e.backtrace
-end
-
-
- -
-

- - + (Object) new(*args) - - - - - -

-
- -

:nocov:

- - -
-
-
- - -
- - - - -
-
-
-
-9
-10
-11
-12
-13
-
-
# File 'lib/active_model_serializers/adapter.rb', line 9
-
-def new(*args)
-  fail ArgumentError, 'Adapters inherit from Adapter::Base.' \
-    "Adapter.new called with args: '#{args.inspect}', from" \
-    "'caller[0]'."
-end
-
-
- -
-

- - + (Object) register(name, klass = name) - - - - - -

-
- -
- Note: -
-

The registered name strips out 'ActiveModelSerializers::Adapter::' -so that registering 'ActiveModelSerializers::Adapter::Json' and -'Json' will both register as 'json'.

-
-
- - -

Adds an adapter 'klass' with 'name' to the -'adapter_map' Names are stringified and underscored

- - -
-
-
- -
-

Examples:

- - -
AMS::Adapter.register(:my_adapter, MyAdapter)
- -
-

Parameters:

-
    - -
  • - - name - - - (Symbol, String, Class) - - - - — -
    -

    name of the registered adapter

    -
    - -
  • - -
  • - - klass - - - (Class) - - - (defaults to: name) - - - — -
    -

    adapter class itself, optional if name is the class

    -
    - -
  • - -
- - -
- - - - -
-
-
-
-50
-51
-52
-53
-54
-
-
# File 'lib/active_model_serializers/adapter.rb', line 50
-
-def register(name, klass = name)
-  name = name.to_s.gsub(/\AActiveModelSerializers::Adapter::/, ''.freeze)
-  adapter_map[name.underscore] = klass
-  self
-end
-
-
- -
-

- - + (Object) registered_name(adapter_class) - - - - - -

- - - - -
-
-
-
-56
-57
-58
-
-
# File 'lib/active_model_serializers/adapter.rb', line 56
-
-def registered_name(adapter_class)
-  ADAPTER_MAP.key adapter_class
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/Attributes.html b/ActiveModelSerializers/Adapter/Attributes.html deleted file mode 100644 index cb12c075..00000000 --- a/ActiveModelSerializers/Adapter/Attributes.html +++ /dev/null @@ -1,221 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Adapter::Attributes - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Adapter::Attributes - - - -

- -
- -
Inherits:
-
- Base - -
    -
  • Object
  • - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter/attributes.rb
- -
-
- -
-

Direct Known Subclasses

-

ActiveModel::Serializer::Adapter::Attributes

-
- - - - - - -

Instance Attribute Summary

- -

Attributes inherited from Base

-

#instance_options, #serializer

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods inherited from Base

-

#as_json, cache_key, #cache_key, default_key_transform, #fragment_cache, fragment_cache, inherited, #initialize, transform, transform_key_casing!

-
-

Constructor Details

- -

This class inherits a constructor from ActiveModelSerializers::Adapter::Base

- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) serializable_hash(options = nil) - - - - - -

- - - - -
-
-
-
-4
-5
-6
-7
-8
-
-
# File 'lib/active_model_serializers/adapter/attributes.rb', line 4
-
-def serializable_hash(options = nil)
-  options = serialization_options(options)
-  options[:fields] ||= instance_options[:fields]
-  serializer.serializable_hash(instance_options, options, self)
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/Base.html b/ActiveModelSerializers/Adapter/Base.html deleted file mode 100644 index a9b14f07..00000000 --- a/ActiveModelSerializers/Adapter/Base.html +++ /dev/null @@ -1,1082 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Adapter::Base - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Adapter::Base - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter/base.rb
- -
-
- -
-

Direct Known Subclasses

-

ActiveModel::Serializer::Adapter::Base, Attributes, Json, JsonApi, Null

-
- - - - -

Instance Attribute Summary (collapse)

- - - - - - -

- Class Method Summary - (collapse) -

- - - -

- Instance Method Summary - (collapse) -

- - - - -
-

Constructor Details

- -
-

- - - (Base) initialize(serializer, options = {}) - - - - - -

-
- -

Returns a new instance of Base

- - -
-
-
- - -
- - - - -
-
-
-
-47
-48
-49
-50
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 47
-
-def initialize(serializer, options = {})
-  @serializer = serializer
-  @instance_options = options
-end
-
-
- -
- -
-

Instance Attribute Details

- - - -
-

- - - (Object) instance_options (readonly) - - - - - -

-
- -

Returns the value of attribute instance_options

- - -
-
-
- - -
- - - - -
-
-
-
-45
-46
-47
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 45
-
-def instance_options
-  @instance_options
-end
-
-
- - - -
-

- - - (Object) serializer (readonly) - - - - - -

-
- -

Returns the value of attribute serializer

- - -
-
-
- - -
- - - - -
-
-
-
-45
-46
-47
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 45
-
-def serializer
-  @serializer
-end
-
-
- -
- - -
-

Class Method Details

- - -
-

- - + (Object) cache_key - - - - - -

- - - - -
-
-
-
-37
-38
-39
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 37
-
-def self.cache_key
-  @cache_key ||= ActiveModelSerializers::Adapter.registered_name(self)
-end
-
-
- -
-

- - + (Symbol) default_key_transform - - - - - -

-
- -

Sets the default transform for the adapter.

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Symbol) - - - - — -
    -

    the default transform for the adapter

    -
    - -
  • - -
- -
- - - - -
-
-
-
-14
-15
-16
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 14
-
-def self.default_key_transform
-  :unaltered
-end
-
-
- -
-

- - + (Object) fragment_cache(cached_hash, non_cached_hash) - - - - - -

- - - - -
-
-
-
-41
-42
-43
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 41
-
-def self.fragment_cache(cached_hash, non_cached_hash)
-  non_cached_hash.merge cached_hash
-end
-
-
- -
-

- - + (Object) inherited(subclass) - - - - - -

-
- -

Automatically register adapters when subclassing

- - -
-
-
- - -
- - - - -
-
-
-
-7
-8
-9
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 7
-
-def self.inherited(subclass)
-  ActiveModelSerializers::Adapter.register(subclass)
-end
-
-
- -
-

- - + (Symbol) transform(options) - - - - - -

-
- -

Determines the transform to use in order of precedence:

- -
adapter option, global config, adapter default.
- - -
-
-
-

Parameters:

-
    - -
  • - - options - - - (Object) - - - -
  • - -
- -

Returns:

-
    - -
  • - - - (Symbol) - - - - — -
    -

    the transform to use

    -
    - -
  • - -
- -
- - - - -
-
-
-
-23
-24
-25
-26
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 23
-
-def self.transform(options)
-  return options[:key_transform] if options && options[:key_transform]
-  ActiveModelSerializers.config.key_transform || default_key_transform
-end
-
-
- -
-

- - + (Symbol) transform_key_casing!(value, options) - - - - - -

-
- -

Transforms the casing of the supplied value.

- - -
-
-
-

Parameters:

-
    - -
  • - - value - - - (Object) - - - - — -
    -

    the value to be transformed

    -
    - -
  • - -
  • - - options - - - (Object) - - - - — -
    -

    serializable resource options

    -
    - -
  • - -
- -

Returns:

-
    - -
  • - - - (Symbol) - - - - — -
    -

    the default transform for the adapter

    -
    - -
  • - -
- -
- - - - -
-
-
-
-33
-34
-35
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 33
-
-def self.transform_key_casing!(value, options)
-  KeyTransform.send(transform(options), value)
-end
-
-
- -
- -
-

Instance Method Details

- - -
-

- - - (Object) as_json(options = nil) - - - - - -

- - - - -
-
-
-
-58
-59
-60
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 58
-
-def as_json(options = nil)
-  serializable_hash(options)
-end
-
-
- -
-

- - - (Object) cache_key - - - - - -

- - - - -
-
-
-
-62
-63
-64
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 62
-
-def cache_key
-  self.class.cache_key
-end
-
-
- -
-

- - - (Object) fragment_cache(cached_hash, non_cached_hash) - - - - - -

- - - - -
-
-
-
-66
-67
-68
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 66
-
-def fragment_cache(cached_hash, non_cached_hash)
-  self.class.fragment_cache(cached_hash, non_cached_hash)
-end
-
-
- -
-

- - - (Object) serializable_hash(_options = nil) - - - - - -

-
- -

Subclasses that implement this method must first call

- -
options = serialization_options(options)
-
- - -
-
-
- - -
- - - - -
-
-
-
-54
-55
-56
-
-
# File 'lib/active_model_serializers/adapter/base.rb', line 54
-
-def serializable_hash(_options = nil)
-  fail NotImplementedError, 'This is an abstract method. Should be implemented at the concrete adapter.'
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/Json.html b/ActiveModelSerializers/Adapter/Json.html deleted file mode 100644 index ed8d677e..00000000 --- a/ActiveModelSerializers/Adapter/Json.html +++ /dev/null @@ -1,329 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Adapter::Json - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Adapter::Json - - - -

- -
- -
Inherits:
-
- Base - -
    -
  • Object
  • - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter/json.rb
- -
-
- -
-

Direct Known Subclasses

-

ActiveModel::Serializer::Adapter::Json

-
- - - - - - -

Instance Attribute Summary

- -

Attributes inherited from Base

-

#instance_options, #serializer

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods inherited from Base

-

#as_json, cache_key, #cache_key, default_key_transform, #fragment_cache, fragment_cache, inherited, #initialize, transform, transform_key_casing!

-
-

Constructor Details

- -

This class inherits a constructor from ActiveModelSerializers::Adapter::Base

- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) meta - - - - - -

- - - - -
-
-
-
-12
-13
-14
-
-
# File 'lib/active_model_serializers/adapter/json.rb', line 12
-
-def meta
-  instance_options.fetch(:meta, nil)
-end
-
-
- -
-

- - - (Object) meta_key - - - - - -

- - - - -
-
-
-
-16
-17
-18
-
-
# File 'lib/active_model_serializers/adapter/json.rb', line 16
-
-def meta_key
-  instance_options.fetch(:meta_key, 'meta'.freeze)
-end
-
-
- -
-

- - - (Object) serializable_hash(options = nil) - - - - - -

- - - - -
-
-
-
-4
-5
-6
-7
-8
-9
-10
-
-
# File 'lib/active_model_serializers/adapter/json.rb', line 4
-
-def serializable_hash(options = nil)
-  options = serialization_options(options)
-  serialized_hash = { root => Attributes.new(serializer, instance_options).serializable_hash(options) }
-  serialized_hash[meta_key] = meta unless meta.blank?
-
-  self.class.transform_key_casing!(serialized_hash, instance_options)
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/JsonApi.html b/ActiveModelSerializers/Adapter/JsonApi.html deleted file mode 100644 index 981451b9..00000000 --- a/ActiveModelSerializers/Adapter/JsonApi.html +++ /dev/null @@ -1,860 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Adapter::JsonApi - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Adapter::JsonApi - - - -

- -
- -
Inherits:
-
- Base - -
    -
  • Object
  • - - - - - -
- show all - -
- - - - -
Extended by:
-
ActiveSupport::Autoload
- - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter/json_api.rb,
- lib/active_model_serializers/adapter/json_api/link.rb,
lib/active_model_serializers/adapter/json_api/meta.rb,
lib/active_model_serializers/adapter/json_api/error.rb,
lib/active_model_serializers/adapter/json_api/jsonapi.rb,
lib/active_model_serializers/adapter/json_api/relationship.rb,
lib/active_model_serializers/adapter/json_api/deserialization.rb,
lib/active_model_serializers/adapter/json_api/pagination_links.rb,
lib/active_model_serializers/adapter/json_api/resource_identifier.rb
-
- -
-
- -
-

Direct Known Subclasses

-

ActiveModel::Serializer::Adapter::JsonApi

-
-

Defined Under Namespace

-

- - - Modules: Deserialization, Error, Jsonapi - - - - Classes: Link, Meta, PaginationLinks, Relationship, ResourceIdentifier - - -

- - - - - - -

Instance Attribute Summary

- -

Attributes inherited from Base

-

#instance_options, #serializer

- - - -

- Class Method Summary - (collapse) -

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - - -

Methods inherited from Base

-

#as_json, #cache_key, cache_key, inherited, transform, transform_key_casing!

-
-

Constructor Details

- -
-

- - - (JsonApi) initialize(serializer, options = {}) - - - - - -

-
- -

Returns a new instance of JsonApi

- - -
-
-
- - -
- - - - -
-
-
-
-49
-50
-51
-52
-53
-
-
# File 'lib/active_model_serializers/adapter/json_api.rb', line 49
-
-def initialize(serializer, options = {})
-  super
-  @include_directive = JSONAPI::IncludeDirective.new(options[:include], allow_wildcard: true)
-  @fieldset = options[:fieldset] || ActiveModel::Serializer::Fieldset.new(options.delete(:fields))
-end
-
-
- -
- - -
-

Class Method Details

- - -
-

- - + (Object) default_key_transform - - - - - -

- - - - -
-
-
-
-34
-35
-36
-
-
# File 'lib/active_model_serializers/adapter/json_api.rb', line 34
-
-def self.default_key_transform
-  :dash
-end
-
-
- -
-

- - + (Object) fragment_cache(cached_hash, non_cached_hash, root = true) - - - - - -

- - - - -
-
-
-
-38
-39
-40
-41
-42
-43
-44
-45
-46
-47
-
-
# File 'lib/active_model_serializers/adapter/json_api.rb', line 38
-
-def self.fragment_cache(cached_hash, non_cached_hash, root = true)
-  core_cached       = cached_hash.first
-  core_non_cached   = non_cached_hash.first
-  no_root_cache     = cached_hash.delete_if { |key, _value| key == core_cached[0] }
-  no_root_non_cache = non_cached_hash.delete_if { |key, _value| key == core_non_cached[0] }
-  cached_resource   = (core_cached[1]) ? core_cached[1].deep_merge(core_non_cached[1]) : core_non_cached[1]
-  hash = root ? { root => cached_resource } : cached_resource
-
-  hash.deep_merge no_root_non_cache.deep_merge no_root_cache
-end
-
-
- -
- -
-

Instance Method Details

- - -
-

- - - (Object) failure_document - - - - - -

-
- -

JSON API Errors TODO: look into caching -definition:

- -
 toplevel_errors array (required)
- toplevel_meta
- toplevel_jsonapi
-
- -

structure:

- -
{
-  errors: toplevel_errors,
-  meta: toplevel_meta,
-  jsonapi: toplevel_jsonapi
-}.reject! {|_,v| v.nil? }
-
- -

prs:

- -
https://github.com/rails-api/active_model_serializers/pull/1004
-
- - -
-
-
- - -
- - - - -
-
-
-
-170
-171
-172
-173
-174
-175
-176
-177
-178
-179
-180
-181
-182
-183
-184
-185
-186
-187
-188
-189
-190
-191
-
-
# File 'lib/active_model_serializers/adapter/json_api.rb', line 170
-
-def failure_document
-  hash = {}
-  # PR Please :)
-  # Jsonapi.add!(hash)
-
-  # toplevel_errors
-  # definition:
-  #   array of unique items of type 'error'
-  # structure:
-  #   [
-  #     error,
-  #     error
-  #   ]
-  if serializer.respond_to?(:each)
-    hash[:errors] = serializer.flat_map do |error_serializer|
-      Error.resource_errors(error_serializer, instance_options)
-    end
-  else
-    hash[:errors] = Error.resource_errors(serializer, instance_options)
-  end
-  hash
-end
-
-
- -
-

- - - (Object) fragment_cache(cached_hash, non_cached_hash) - - - - - -

- - - - -
-
-
-
-66
-67
-68
-69
-
-
# File 'lib/active_model_serializers/adapter/json_api.rb', line 66
-
-def fragment_cache(cached_hash, non_cached_hash)
-  root = !instance_options.include?(:include)
-  self.class.fragment_cache(cached_hash, non_cached_hash, root)
-end
-
-
- -
-

- - - (Object) serializable_hash - - - - - -

-
- - -
- - - - -
-
-
-
-57
-58
-59
-60
-61
-62
-63
-64
-
-
# File 'lib/active_model_serializers/adapter/json_api.rb', line 57
-
-def serializable_hash(*)
-  document = if serializer.success?
-               success_document
-             else
-               failure_document
-             end
-  self.class.transform_key_casing!(document, instance_options)
-end
-
-
- -
-

- - - (Object) success_document - - - - - -

-
- -

Primary data definition:

- -
 toplevel_data (required)
- toplevel_included
- toplevel_meta
- toplevel_links
- toplevel_jsonapi
-
- -

structure:

- -
{
-  data: toplevel_data,
-  included: toplevel_included,
-  meta: toplevel_meta,
-  links: toplevel_links,
-  jsonapi: toplevel_jsonapi
-}.reject! {|_,v| v.nil? }
-
- -

rubocop:disable Metrics/CyclomaticComplexity

- - -
-
-
- - -
- - - - -
-
-
-
-87
-88
-89
-90
-91
-92
-93
-94
-95
-96
-97
-98
-99
-100
-101
-102
-103
-104
-105
-106
-107
-108
-109
-110
-111
-112
-113
-114
-115
-116
-117
-118
-119
-120
-121
-122
-123
-124
-125
-126
-127
-128
-129
-130
-131
-132
-133
-134
-135
-136
-137
-138
-139
-140
-141
-142
-143
-144
-145
-146
-147
-148
-149
-150
-151
-152
-153
-
-
# File 'lib/active_model_serializers/adapter/json_api.rb', line 87
-
-def success_document
-  is_collection = serializer.respond_to?(:each)
-  serializers = is_collection ? serializer : [serializer]
-  primary_data, included = resource_objects_for(serializers)
-
-  hash = {}
-  # toplevel_data
-  # definition:
-  #   oneOf
-  #     resource
-  #     array of unique items of type 'resource'
-  #     null
-  #
-  # description:
-  #   The document's "primary data" is a representation of the resource or collection of resources
-  #   targeted by a request.
-  #
-  #   Singular: the resource object.
-  #
-  #   Collection: one of an array of resource objects, an array of resource identifier objects, or
-  #   an empty array ([]), for requests that target resource collections.
-  #
-  #   None: null if the request is one that might correspond to a single resource, but doesn't currently.
-  # structure:
-  #  if serializable_resource.resource?
-  #    resource
-  #  elsif serializable_resource.collection?
-  #    [
-  #      resource,
-  #      resource
-  #    ]
-  #  else
-  #    nil
-  #  end
-  hash[:data] = is_collection ? primary_data : primary_data[0]
-  # toplevel_included
-  #   alias included
-  # definition:
-  #   array of unique items of type 'resource'
-  #
-  # description:
-  #   To reduce the number of HTTP requests, servers **MAY** allow
-  #   responses that include related resources along with the requested primary
-  #   resources. Such responses are called "compound documents".
-  # structure:
-  #     [
-  #       resource,
-  #       resource
-  #     ]
-  hash[:included] = included if included.any?
-
-  Jsonapi.add!(hash)
-
-  if instance_options[:links]
-    hash[:links] ||= {}
-    hash[:links].update(instance_options[:links])
-  end
-
-  if is_collection && serializer.paginated?
-    hash[:links] ||= {}
-    hash[:links].update(pagination_links_for(serializer))
-  end
-
-  hash[:meta] = instance_options[:meta] unless instance_options[:meta].blank?
-
-  hash
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/JsonApi/Deserialization.html b/ActiveModelSerializers/Adapter/JsonApi/Deserialization.html deleted file mode 100644 index 07d31158..00000000 --- a/ActiveModelSerializers/Adapter/JsonApi/Deserialization.html +++ /dev/null @@ -1,1059 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Adapter::JsonApi::Deserialization - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Adapter::JsonApi::Deserialization - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter/json_api/deserialization.rb
- -
-
- -

Overview

-
- -

NOTE(Experimental): This is an experimental feature. Both the interface and -internals could be subject to changes.

- - -
-
-
- - -
-

Constant Summary

- -
- -
InvalidDocument = - -
-
Class.new(ArgumentError)
- -
- - - - - - - - - -

- Class Method Summary - (collapse) -

- - - - - - -
-

Class Method Details

- - -
-

- - + (Object) field_key(field, options) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - -
-
-
-
-152
-153
-154
-
-
# File 'lib/active_model_serializers/adapter/json_api/deserialization.rb', line 152
-
-def field_key(field, options)
-  (options[:keys] || {}).fetch(field.to_sym, field).to_sym
-end
-
-
- -
-

- - + (Object) filter_fields(fields, options) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - -
-
-
-
-143
-144
-145
-146
-147
-148
-149
-
-
# File 'lib/active_model_serializers/adapter/json_api/deserialization.rb', line 143
-
-def filter_fields(fields, options)
-  if (only = options[:only])
-    fields.slice!(*Array(only).map(&:to_s))
-  elsif (except = options[:except])
-    fields.except!(*Array(except).map(&:to_s))
-  end
-end
-
-
- -
-

- - + (Object) parse(document, options = {}) - - - - - -

-
- -

Same as parse!, but returns an empty hash instead of raising -InvalidDocument on invalid payloads.

- - -
-
-
- - -
- - - - -
-
-
-
-83
-84
-85
-86
-87
-88
-89
-90
-91
-92
-93
-94
-95
-96
-97
-98
-99
-100
-101
-102
-103
-104
-
-
# File 'lib/active_model_serializers/adapter/json_api/deserialization.rb', line 83
-
-def parse(document, options = {})
-  document = document.dup.permit!.to_h if document.is_a?(ActionController::Parameters)
-
-  validate_payload(document) do |invalid_document, reason|
-    yield invalid_document, reason if block_given?
-    return {}
-  end
-
-  primary_data = document['data']
-  attributes = primary_data['attributes'] || {}
-  attributes['id'] = primary_data['id'] if primary_data['id']
-  relationships = primary_data['relationships'] || {}
-
-  filter_fields(attributes, options)
-  filter_fields(relationships, options)
-
-  hash = {}
-  hash.merge!(parse_attributes(attributes, options))
-  hash.merge!(parse_relationships(relationships, options))
-
-  hash
-end
-
-
- -
-

- - + (Hash) parse!(document, options = {}) - - - - - -

-
- -

Transform a JSON API document, containing a single data object, into a hash -that is ready for ActiveRecord::Base.new() and such. Raises InvalidDocument -if the payload is not properly formatted.

- - -
-
-
- -
-

Examples:

- - -
document = {
-  data: {
-    id: 1,
-    type: 'post',
-    attributes: {
-      title: 'Title 1',
-      date: '2015-12-20'
-    },
-    associations: {
-      author: {
-        data: {
-          type: 'user',
-          id: 2
-        }
-      },
-      second_author: {
-        data: nil
-      },
-      comments: {
-        data: [{
-          type: 'comment',
-          id: 3
-        },{
-          type: 'comment',
-          id: 4
-        }]
-      }
-    }
-  }
-}
-
-parse(document) #=>
-  # {
-  #   title: 'Title 1',
-  #   date: '2015-12-20',
-  #   author_id: 2,
-  #   second_author_id: nil
-  #   comment_ids: [3, 4]
-  # }
-
-parse(document, only: [:title, :date, :author],
-                keys: { date: :published_at },
-                polymorphic: [:author]) #=>
-  # {
-  #   title: 'Title 1',
-  #   published_at: '2015-12-20',
-  #   author_id: '2',
-  #   author_type: 'people'
-  # }
- -
-

Parameters:

-
    - -
  • - - document - - - (Hash|ActionController::Parameters) - - - -
  • - -
  • - - options - - - (Hash) - - - (defaults to: {}) - - - — -
    -

    only: Array of symbols of whitelisted fields. except: Array of symbols of -blacklisted fields. keys: Hash of translated keys (e.g. :author => -:user). polymorphic: Array of symbols of polymorphic fields.

    -
    - -
  • - -
- -

Returns:

-
    - -
  • - - - (Hash) - - - -
  • - -
- -
- - - - -
-
-
-
-75
-76
-77
-78
-79
-
-
# File 'lib/active_model_serializers/adapter/json_api/deserialization.rb', line 75
-
-def parse!(document, options = {})
-  parse(document, options) do |invalid_payload, reason|
-    fail InvalidDocument, "Invalid payload (#{reason}): #{invalid_payload}"
-  end
-end
-
-
- -
-

- - + (Object) parse_attributes(attributes, options) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - -
-
-
-
-157
-158
-159
-160
-161
-
-
# File 'lib/active_model_serializers/adapter/json_api/deserialization.rb', line 157
-
-def parse_attributes(attributes, options)
-  transform_keys(attributes, options)
-    .map { |(k, v)| { field_key(k, options) => v } }
-    .reduce({}, :merge)
-end
-
-
- -
-

- - + (Hash{Symbol, Object}) parse_relationship(assoc_name, assoc_data, options) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- -

Given an association name, and a relationship data attribute, build a hash -mapping the corresponding ActiveRecord attribute to the corresponding -value.

- - -
-
-
- -
-

Examples:

- - -
parse_relationship(:comments, [{ 'id' => '1', 'type' => 'comments' },
-                               { 'id' => '2', 'type' => 'comments' }],
-                              {})
- # => { :comment_ids => ['1', '2'] }
-parse_relationship(:author, { 'id' => '1', 'type' => 'users' }, {})
- # => { :author_id => '1' }
-parse_relationship(:author, nil, {})
- # => { :author_id => nil }
- -
-

Parameters:

-
    - -
  • - - assoc_name - - - (Symbol) - - - -
  • - -
  • - - assoc_data - - - (Hash) - - - -
  • - -
  • - - options - - - (Hash) - - - -
  • - -
- -

Returns:

-
    - -
  • - - - (Hash{Symbol, Object}) - - - -
  • - -
- -
- - - - -
-
-
-
-181
-182
-183
-184
-185
-186
-187
-188
-189
-190
-191
-192
-193
-194
-195
-196
-
-
# File 'lib/active_model_serializers/adapter/json_api/deserialization.rb', line 181
-
-def parse_relationship(assoc_name, assoc_data, options)
-  prefix_key = field_key(assoc_name, options).to_s.singularize
-  hash =
-    if assoc_data.is_a?(Array)
-      { "#{prefix_key}_ids".to_sym => assoc_data.map { |ri| ri['id'] } }
-    else
-      { "#{prefix_key}_id".to_sym => assoc_data ? assoc_data['id'] : nil }
-    end
-
-  polymorphic = (options[:polymorphic] || []).include?(assoc_name.to_sym)
-  if polymorphic
-    hash["#{prefix_key}_type".to_sym] = assoc_data.present? ? assoc_data['type'] : nil
-  end
-
-  hash
-end
-
-
- -
-

- - + (Object) parse_relationships(relationships, options) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - -
-
-
-
-199
-200
-201
-202
-203
-
-
# File 'lib/active_model_serializers/adapter/json_api/deserialization.rb', line 199
-
-def parse_relationships(relationships, options)
-  transform_keys(relationships, options)
-    .map { |(k, v)| parse_relationship(k, v['data'], options) }
-    .reduce({}, :merge)
-end
-
-
- -
-

- - + (Object) transform_keys(hash, options) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- - -
-
-
- - -
- - - - -
-
-
-
-206
-207
-208
-209
-
-
# File 'lib/active_model_serializers/adapter/json_api/deserialization.rb', line 206
-
-def transform_keys(hash, options)
-  transform = options[:key_transform] || :underscore
-  KeyTransform.send(transform, hash)
-end
-
-
- -
-

- - + (Object) validate_payload(payload) - - - - - -

-
-

- This method is part of a private API. - You should avoid using this method if possible, as it may be removed or be changed in the future. -

- -

Checks whether a payload is compliant with the JSON API spec.

- -

rubocop:disable Metrics/CyclomaticComplexity

- - -
-
-
- - -
- - - - -
-
-
-
-110
-111
-112
-113
-114
-115
-116
-117
-118
-119
-120
-121
-122
-123
-124
-125
-126
-127
-128
-129
-130
-131
-132
-133
-134
-135
-136
-137
-138
-139
-
-
# File 'lib/active_model_serializers/adapter/json_api/deserialization.rb', line 110
-
-def validate_payload(payload)
-  unless payload.is_a?(Hash)
-    yield payload, 'Expected hash'
-    return
-  end
-
-  primary_data = payload['data']
-  unless primary_data.is_a?(Hash)
-    yield payload, { data: 'Expected hash' }
-    return
-  end
-
-  attributes = primary_data['attributes'] || {}
-  unless attributes.is_a?(Hash)
-    yield payload, { data: { attributes: 'Expected hash or nil' } }
-    return
-  end
-
-  relationships = primary_data['relationships'] || {}
-  unless relationships.is_a?(Hash)
-    yield payload, { data: { relationships: 'Expected hash or nil' } }
-    return
-  end
-
-  relationships.each do |(key, value)|
-    unless value.is_a?(Hash) && value.key?('data')
-      yield payload, { data: { relationships: { key => 'Expected hash with :data key' } } }
-    end
-  end
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/JsonApi/Error.html b/ActiveModelSerializers/Adapter/JsonApi/Error.html deleted file mode 100644 index 4a78a948..00000000 --- a/ActiveModelSerializers/Adapter/JsonApi/Error.html +++ /dev/null @@ -1,471 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Adapter::JsonApi::Error - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Adapter::JsonApi::Error - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter/json_api/error.rb
- -
-
- - -

Constant Summary

- -
- -
UnknownSourceTypeError = -
-
- -

rubocop:disable Style/AsciiComments

- - -
-
-
- - -
-
-
Class.new(ArgumentError)
- -
- - - - - - - - - -

- Class Method Summary - (collapse) -

- - - - - - -
-

Class Method Details

- - -
-

- - + (Object) attribute_error_objects(attribute_name, attribute_errors) - - - - - -

-
- -

definition:

- -
JSON Object
-
- -

properties:

- -
☐ id      : String
-☐ status  : String
-☐ code    : String
-☐ title   : String
-☑ detail  : String
-☐ links
-☐ meta
-☑ error_source
- -

description:

- -
id     : A unique identifier for this particular occurrence of the problem.
-status : The HTTP status code applicable to this problem, expressed as a string value
-code   : An application-specific error code, expressed as a string value.
-title  : A short, human-readable summary of the problem. It **SHOULD NOT** change from
-  occurrence to occurrence of the problem, except for purposes of localization.
-detail : A human-readable explanation specific to this occurrence of the problem.
- -

structure:

- -
{
-  title: 'SystemFailure',
-  detail: 'something went terribly wrong',
-  status: '500'
-}.merge!(errorSource)
-
- - -
-
-
- - -
- - - - -
-
-
-
-47
-48
-49
-50
-51
-52
-53
-54
-
-
# File 'lib/active_model_serializers/adapter/json_api/error.rb', line 47
-
-def self.attribute_error_objects(attribute_name, attribute_errors)
-  attribute_errors.map do |attribute_error|
-    {
-      source: error_source(:pointer, attribute_name),
-      detail: attribute_error
-    }
-  end
-end
-
-
- -
-

- - + (Object) error_source(source_type, attribute_name) - - - - - -

-
- -

errorSource description:

- -
oneOf
-  ☑ pointer   : String
-  ☑ parameter : String
- -

description:

- -
pointer: A JSON Pointer RFC6901 to the associated entity in the request document e.g. "/data"
-for a primary data object, or "/data/attributes/title" for a specific attribute.
-https://tools.ietf.org/html/rfc6901
-
-parameter: A string indicating which query parameter caused the error
- -

structure:

- -
if is_attribute?
-  {
-    pointer: '/data/attributes/red-button'
-  }
-else
-  {
-    parameter: 'pres'
-  }
-end
-
- - -
-
-
- - -
- - - - -
-
-
-
-78
-79
-80
-81
-82
-83
-84
-85
-86
-87
-88
-89
-90
-91
-
-
# File 'lib/active_model_serializers/adapter/json_api/error.rb', line 78
-
-def self.error_source(source_type, attribute_name)
-  case source_type
-  when :pointer
-    {
-      pointer: ActiveModelSerializers::JsonPointer.new(:attribute, attribute_name)
-    }
-  when :parameter
-    {
-      parameter: attribute_name
-    }
-  else
-    fail UnknownSourceTypeError, "Unknown source type '#{source_type}' for attribute_name '#{attribute_name}'"
-  end
-end
-
-
- -
-

- - + (Array<Symbol, Array<String>>) resource_errors(error_serializer, options) - - - - - -

-
- -

Builds a JSON API Errors Object JSON API Errors

- - -
-
-
-

Parameters:

- - -

Returns:

-
    - -
  • - - - (Array<Symbol, Array<String>>) - - - - — -
    -

    i.e. attribute_name, [attribute_errors]

    -
    - -
  • - -
- -
- - - - -
-
-
-
-13
-14
-15
-16
-17
-18
-19
-
-
# File 'lib/active_model_serializers/adapter/json_api/error.rb', line 13
-
-def self.resource_errors(error_serializer, options)
-  error_serializer.as_json.flat_map do |attribute_name, attribute_errors|
-    attribute_name = JsonApi.send(:transform_key_casing!, attribute_name,
-      options)
-    attribute_error_objects(attribute_name, attribute_errors)
-  end
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/JsonApi/Jsonapi.html b/ActiveModelSerializers/Adapter/JsonApi/Jsonapi.html deleted file mode 100644 index b70aecf2..00000000 --- a/ActiveModelSerializers/Adapter/JsonApi/Jsonapi.html +++ /dev/null @@ -1,365 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Adapter::JsonApi::Jsonapi - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Adapter::JsonApi::Jsonapi - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter/json_api/jsonapi.rb
- -
-
- -

Overview

-
- -

toplevel_jsonapi definition:

- -
JSON Object
-
- -

properties:

- -
version : String
-meta
- -

description:

- -
An object describing the server's implementation
- -

structure:

- -
{
-  version: ActiveModelSerializers.config.jsonapi_version,
-  meta: ActiveModelSerializers.config.jsonapi_toplevel_meta
-}.reject! { |_, v| v.blank? }
-
- -

prs:

- -
https://github.com/rails-api/active_model_serializers/pull/1050
-
- - -
-
-
- - -
- - - - - - - -

- Class Method Summary - (collapse) -

- - - - - - -
-

Class Method Details

- - -
-

- - + (Object) add!(hash) - - - - - -

- - - - -
-
-
-
-26
-27
-28
-
-
# File 'lib/active_model_serializers/adapter/json_api/jsonapi.rb', line 26
-
-def add!(hash)
-  hash.merge!(object) if include_object?
-end
-
-
- -
-

- - + (Boolean) include_object? - - - - - -

-
- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-30
-31
-32
-
-
# File 'lib/active_model_serializers/adapter/json_api/jsonapi.rb', line 30
-
-def include_object?
-  ActiveModelSerializers.config.jsonapi_include_toplevel_object
-end
-
-
- -
-

- - + (Object) object - - - - - -

-
- -

TODO: see if we can cache this

- - -
-
-
- - -
- - - - -
-
-
-
-35
-36
-37
-38
-39
-40
-41
-42
-43
-44
-45
-
-
# File 'lib/active_model_serializers/adapter/json_api/jsonapi.rb', line 35
-
-def object
-  object = {
-    jsonapi: {
-      version: ActiveModelSerializers.config.jsonapi_version,
-      meta: ActiveModelSerializers.config.jsonapi_toplevel_meta
-    }
-  }
-  object[:jsonapi].reject! { |_, v| v.blank? }
-
-  object
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/JsonApi/Link.html b/ActiveModelSerializers/Adapter/JsonApi/Link.html deleted file mode 100644 index 3dd7294e..00000000 --- a/ActiveModelSerializers/Adapter/JsonApi/Link.html +++ /dev/null @@ -1,475 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Adapter::JsonApi::Link - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Adapter::JsonApi::Link - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - -
Includes:
-
SerializationContext::UrlHelpers
- - - - - -
Defined in:
-
lib/active_model_serializers/adapter/json_api/link.rb
- -
-
- -

Overview

-
- -

link definition:

- -
oneOf
-  linkString
-  linkObject
-
- -

description:

- -
A link **MUST** be represented as either: a string containing the link's URL or a link
-object."
- -

structure:

- -
if href?
-  linkString
-else
-  linkObject
-end
-
- -

linkString definition:

- -
URI
-
- -

description:

- -
A string containing the link's URL.
- -

structure:

- -
'http://example.com/link-string'
-
- -

linkObject definition:

- -
JSON Object
-
- -

properties:

- -
href (required) : URI
-meta
- -

structure:

- -
{
-  href: 'http://example.com/link-object',
-  meta: meta,
-}.reject! {|_,v| v.nil? }
-
- - -
-
-
- - -
- - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods included from SerializationContext::UrlHelpers

-

#default_url_options, included

-
-

Constructor Details

- -
-

- - - (Link) initialize(serializer, value) - - - - - -

-
- -

Returns a new instance of Link

- - -
-
-
- - -
- - - - -
-
-
-
-44
-45
-46
-47
-48
-49
-50
-51
-52
-53
-54
-55
-
-
# File 'lib/active_model_serializers/adapter/json_api/link.rb', line 44
-
-def initialize(serializer, value)
-  @_routes ||= nil # handles warning
-  # actionpack-4.0.13/lib/action_dispatch/routing/route_set.rb:417: warning: instance variable @_routes not initialized
-  @object = serializer.object
-  @scope = serializer.scope
-  # Use the return value of the block unless it is nil.
-  if value.respond_to?(:call)
-    @value = instance_eval(&value)
-  else
-    @value = value
-  end
-end
-
-
- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) as_json - - - - - -

- - - - -
-
-
-
-67
-68
-69
-70
-71
-72
-73
-74
-75
-
-
# File 'lib/active_model_serializers/adapter/json_api/link.rb', line 67
-
-def as_json
-  return @value if @value
-
-  hash = {}
-  hash[:href] = @href if defined?(@href)
-  hash[:meta] = @meta if defined?(@meta)
-
-  hash.any? ? hash : nil
-end
-
-
- -
-

- - - (Object) href(value) - - - - - -

- - - - -
-
-
-
-57
-58
-59
-60
-
-
# File 'lib/active_model_serializers/adapter/json_api/link.rb', line 57
-
-def href(value)
-  @href = value
-  nil
-end
-
-
- -
-

- - - (Object) meta(value) - - - - - -

- - - - -
-
-
-
-62
-63
-64
-65
-
-
# File 'lib/active_model_serializers/adapter/json_api/link.rb', line 62
-
-def meta(value)
-  @meta = value
-  nil
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/JsonApi/Meta.html b/ActiveModelSerializers/Adapter/JsonApi/Meta.html deleted file mode 100644 index 330040f9..00000000 --- a/ActiveModelSerializers/Adapter/JsonApi/Meta.html +++ /dev/null @@ -1,301 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Adapter::JsonApi::Meta - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Adapter::JsonApi::Meta - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter/json_api/meta.rb
- -
-
- -

Overview

-
- -

meta definition:

- -
JSON Object
-
- -

description:

- -
Non-standard meta-information that can not be represented as an attribute or relationship.
- -

structure:

- -
{
-  attitude: 'adjustable'
-}
-
- - -
-
-
- - -
- - - - - - - -

- Instance Method Summary - (collapse) -

- - - - -
-

Constructor Details

- -
-

- - - (Meta) initialize(serializer) - - - - - -

-
- -

Returns a new instance of Meta

- - -
-
-
- - -
- - - - -
-
-
-
-15
-16
-17
-18
-19
-20
-21
-22
-23
-24
-25
-
-
# File 'lib/active_model_serializers/adapter/json_api/meta.rb', line 15
-
-def initialize(serializer)
-  @object = serializer.object
-  @scope = serializer.scope
-
-  # Use the return value of the block unless it is nil.
-  if serializer._meta.respond_to?(:call)
-    @value = instance_eval(&serializer._meta)
-  else
-    @value = serializer._meta
-  end
-end
-
-
- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) as_json - - - - - -

- - - - -
-
-
-
-27
-28
-29
-
-
# File 'lib/active_model_serializers/adapter/json_api/meta.rb', line 27
-
-def as_json
-  @value
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/JsonApi/PaginationLinks.html b/ActiveModelSerializers/Adapter/JsonApi/PaginationLinks.html deleted file mode 100644 index a787a9f4..00000000 --- a/ActiveModelSerializers/Adapter/JsonApi/PaginationLinks.html +++ /dev/null @@ -1,440 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Adapter::JsonApi::PaginationLinks - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Adapter::JsonApi::PaginationLinks - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter/json_api/pagination_links.rb
- -
-
- - -

Constant Summary

- -
- -
FIRST_PAGE = - -
-
1
- -
- - - - - -

Instance Attribute Summary (collapse)

- - - - - - -

- Instance Method Summary - (collapse) -

- - - - -
-

Constructor Details

- -
-

- - - (PaginationLinks) initialize(collection, adapter_options) - - - - - -

-
- -

Returns a new instance of PaginationLinks

- - -
-
-
- - -
- - - - -
-
-
-
-9
-10
-11
-12
-13
-
-
# File 'lib/active_model_serializers/adapter/json_api/pagination_links.rb', line 9
-
-def initialize(collection, adapter_options)
-  @collection = collection
-  @adapter_options = adapter_options
-  @context = adapter_options.fetch(:serialization_context)
-end
-
-
- -
- -
-

Instance Attribute Details

- - - -
-

- - - (Object) collection (readonly) - - - - - -

-
- -

Returns the value of attribute collection

- - -
-
-
- - -
- - - - -
-
-
-
-7
-8
-9
-
-
# File 'lib/active_model_serializers/adapter/json_api/pagination_links.rb', line 7
-
-def collection
-  @collection
-end
-
-
- - - -
-

- - - (Object) context (readonly) - - - - - -

-
- -

Returns the value of attribute context

- - -
-
-
- - -
- - - - -
-
-
-
-7
-8
-9
-
-
# File 'lib/active_model_serializers/adapter/json_api/pagination_links.rb', line 7
-
-def context
-  @context
-end
-
-
- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) as_json - - - - - -

- - - - -
-
-
-
-15
-16
-17
-18
-19
-20
-21
-22
-
-
# File 'lib/active_model_serializers/adapter/json_api/pagination_links.rb', line 15
-
-def as_json
-  per_page = collection.try(:per_page) || collection.try(:limit_value) || collection.size
-  pages_from.each_with_object({}) do |(key, value), hash|
-    params = query_parameters.merge(page: { number: value, size: per_page }).to_query
-
-    hash[key] = "#{url(adapter_options)}?#{params}"
-  end
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/JsonApi/Relationship.html b/ActiveModelSerializers/Adapter/JsonApi/Relationship.html deleted file mode 100644 index 5423139c..00000000 --- a/ActiveModelSerializers/Adapter/JsonApi/Relationship.html +++ /dev/null @@ -1,296 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Adapter::JsonApi::Relationship - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Adapter::JsonApi::Relationship - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter/json_api/relationship.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - -
-

Constructor Details

- -
-

- - - (Relationship) initialize(parent_serializer, serializer, serializable_resource_options, args = {}) - - - - - -

-
- - -
- - - - -
-
-
-
-9
-10
-11
-12
-13
-14
-15
-16
-17
-18
-19
-20
-
-
# File 'lib/active_model_serializers/adapter/json_api/relationship.rb', line 9
-
-def initialize(parent_serializer, serializer, serializable_resource_options, args = {})
-  @object = parent_serializer.object
-  @scope = parent_serializer.scope
-  @association_options = args.fetch(:options, {})
-  @serializable_resource_options = serializable_resource_options
-  @data = data_for(serializer)
-  @links = args.fetch(:links, {}).each_with_object({}) do |(key, value), hash|
-    hash[key] = ActiveModelSerializers::Adapter::JsonApi::Link.new(parent_serializer, value).as_json
-  end
-  meta = args.fetch(:meta, nil)
-  @meta = meta.respond_to?(:call) ? parent_serializer.instance_eval(&meta) : meta
-end
-
-
- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) as_json - - - - - -

- - - - -
-
-
-
-22
-23
-24
-25
-26
-27
-28
-29
-30
-31
-
-
# File 'lib/active_model_serializers/adapter/json_api/relationship.rb', line 22
-
-def as_json
-  hash = {}
-  hash[:data] = data if association_options[:include_data]
-  links = self.links
-  hash[:links] = links if links.any?
-  meta = self.meta
-  hash[:meta] = meta if meta
-
-  hash
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/JsonApi/ResourceIdentifier.html b/ActiveModelSerializers/Adapter/JsonApi/ResourceIdentifier.html deleted file mode 100644 index 85511fa2..00000000 --- a/ActiveModelSerializers/Adapter/JsonApi/ResourceIdentifier.html +++ /dev/null @@ -1,264 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Adapter::JsonApi::ResourceIdentifier - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Adapter::JsonApi::ResourceIdentifier - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter/json_api/resource_identifier.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - -
-

Constructor Details

- -
-

- - - (ResourceIdentifier) initialize(serializer, options) - - - - - -

-
- - -
- - - - -
-
-
-
-6
-7
-8
-9
-10
-
-
# File 'lib/active_model_serializers/adapter/json_api/resource_identifier.rb', line 6
-
-def initialize(serializer, options)
-  @id   = id_for(serializer)
-  @type = JsonApi.send(:transform_key_casing!, type_for(serializer),
-    options)
-end
-
-
- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) as_json - - - - - -

- - - - -
-
-
-
-12
-13
-14
-
-
# File 'lib/active_model_serializers/adapter/json_api/resource_identifier.rb', line 12
-
-def as_json
-  { id: id, type: type }
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Adapter/Null.html b/ActiveModelSerializers/Adapter/Null.html deleted file mode 100644 index 1f36c9e9..00000000 --- a/ActiveModelSerializers/Adapter/Null.html +++ /dev/null @@ -1,217 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Adapter::Null - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Adapter::Null - - - -

- -
- -
Inherits:
-
- Base - -
    -
  • Object
  • - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/adapter/null.rb
- -
-
- -
-

Direct Known Subclasses

-

ActiveModel::Serializer::Adapter::Null

-
- - - - - - -

Instance Attribute Summary

- -

Attributes inherited from Base

-

#instance_options, #serializer

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods inherited from Base

-

#as_json, cache_key, #cache_key, default_key_transform, #fragment_cache, fragment_cache, inherited, #initialize, transform, transform_key_casing!

-
-

Constructor Details

- -

This class inherits a constructor from ActiveModelSerializers::Adapter::Base

- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) serializable_hash - - - - - -

- - - - -
-
-
-
-4
-5
-6
-
-
# File 'lib/active_model_serializers/adapter/null.rb', line 4
-
-def serializable_hash(*)
-  {}
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Callbacks.html b/ActiveModelSerializers/Callbacks.html deleted file mode 100644 index d4b99bc9..00000000 --- a/ActiveModelSerializers/Callbacks.html +++ /dev/null @@ -1,142 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Callbacks - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Callbacks - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Concern
- - - - -
Includes:
-
ActiveSupport::Callbacks
- - - - - -
Defined in:
-
lib/active_model_serializers/callbacks.rb
- -
-
- -

Overview

-
- -

ActiveModelSerializers Callbacks

- -

ActiveModelSerializers provides hooks during the life cycle of -serialization and allow you to trigger logic. Available callbacks are:

-
  • -

    around_render

    -
- - -
-
-
- - -

Defined Under Namespace

-

- - - Modules: ClassMethods - - - - -

- - - - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Callbacks/ClassMethods.html b/ActiveModelSerializers/Callbacks/ClassMethods.html deleted file mode 100644 index 70c529aa..00000000 --- a/ActiveModelSerializers/Callbacks/ClassMethods.html +++ /dev/null @@ -1,225 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Callbacks::ClassMethods - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Callbacks::ClassMethods - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model_serializers/callbacks.rb
- -
-
- -

Overview

-
- -

These methods will be included into any ActiveModelSerializers object, -adding callbacks for render.

- - -
-
-
- - -
- - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) around_render(*filters, &blk) - - - - - -

-
- -

Defines a callback that will get called around the render method, whether -it is as_json, to_json, or serializable_hash

- -
class ActiveModelSerializers::SerializableResource
-  include ActiveModelSerializers::Callbacks
-
-  around_render do |args, block|
-    tag_logger do
-      notify_render do
-        block.call(args)
-      end
-    end
-  end
-
-  def as_json
-    run_callbacks :render do
-      adapter.as_json
-    end
-  end
-  # Note: So that we can re-use the instrumenter for as_json, to_json, and
-  # serializable_hash, we aren't using the usual format, which would be:
-  # def render(args)
-  #   adapter.as_json
-  # end
-end
-
- - -
-
-
- - -
- - - - -
-
-
-
-50
-51
-52
-
-
# File 'lib/active_model_serializers/callbacks.rb', line 50
-
-def around_render(*filters, &blk)
-  set_callback(:render, :around, *filters, &blk)
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Deprecate.html b/ActiveModelSerializers/Deprecate.html deleted file mode 100644 index a0893754..00000000 --- a/ActiveModelSerializers/Deprecate.html +++ /dev/null @@ -1,271 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Deprecate - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Deprecate - - - -

- -
- - - - - - - -
Included in:
-
ActiveModel::SerializableResource, ActiveModel::Serializer, ActiveModel::Serializer::Adapter, ActiveModel::Serializer::Adapter::Attributes, ActiveModel::Serializer::Adapter::Base, ActiveModel::Serializer::Adapter::Json, ActiveModel::Serializer::Adapter::JsonApi, ActiveModel::Serializer::Adapter::Null, ActiveModel::Serializer::ArraySerializer
- - - -
Defined in:
-
lib/active_model_serializers/deprecate.rb
- -
-
- - - - - - - - - -

- Class Method Summary - (collapse) -

- - - - - - -
-

Class Method Details

- - -
-

- - + (Object) delegate_and_deprecate(method, delegee) - - - - - -

- - - - -
-
-
-
-46
-47
-48
-49
-
-
# File 'lib/active_model_serializers/deprecate.rb', line 46
-
-def delegate_and_deprecate(method, delegee)
-  delegate method, to: delegee
-  deprecate method, "#{delegee.name}."
-end
-
-
- -
-

- - + (Object) deprecate(name, replacement) - - - - - -

-
- -

Simple deprecation method that deprecates name by wrapping it -up in a dummy method. It warns on each call to the dummy method telling the -user of replacement (unless replacement is :none) -that it is planned to go away.

- - -
-
-
- - -
- - - - -
-
-
-
-31
-32
-33
-34
-35
-36
-37
-38
-39
-40
-41
-42
-43
-44
-
-
# File 'lib/active_model_serializers/deprecate.rb', line 31
-
-def deprecate(name, replacement)
-  old = "_deprecated_#{name}"
-  alias_method old, name
-  class_eval do
-    define_method(name) do |*args, &block|
-      target = is_a?(Module) ? "#{self}." : "#{self.class}#"
-      msg = ["NOTE: #{target}#{name} is deprecated",
-             replacement == :none ? ' with no replacement' : "; use #{replacement} instead",
-             "\n#{target}#{name} called from #{ActiveModelSerializers.location_of_caller.join(":")}"]
-      warn "#{msg.join}."
-      send old, *args, &block
-    end
-  end
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Deserialization.html b/ActiveModelSerializers/Deserialization.html deleted file mode 100644 index e2137a5f..00000000 --- a/ActiveModelSerializers/Deserialization.html +++ /dev/null @@ -1,239 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Deserialization - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Deserialization - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model_serializers/deserialization.rb
- -
-
- - - - - - - - - -

- Class Method Summary - (collapse) -

- - - - - - -
-

Class Method Details

- - -
-

- - + (Object) jsonapi_parse(*args) - - - - - -

- - - - -
-
-
-
-5
-6
-7
-
-
# File 'lib/active_model_serializers/deserialization.rb', line 5
-
-def jsonapi_parse(*args)
-  Adapter::JsonApi::Deserialization.parse(*args)
-end
-
-
- -
-

- - + (Object) jsonapi_parse!(*args) - - - - - -

-
- -

:nocov:

- - -
-
-
- - -
- - - - -
-
-
-
-10
-11
-12
-
-
# File 'lib/active_model_serializers/deserialization.rb', line 10
-
-def jsonapi_parse!(*args)
-  Adapter::JsonApi::Deserialization.parse!(*args)
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/JsonPointer.html b/ActiveModelSerializers/JsonPointer.html deleted file mode 100644 index fca8ff91..00000000 --- a/ActiveModelSerializers/JsonPointer.html +++ /dev/null @@ -1,189 +0,0 @@ - - - - - - Module: ActiveModelSerializers::JsonPointer - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::JsonPointer - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model_serializers/json_pointer.rb
- -
-
- - -

Constant Summary

- -
- -
POINTERS = - -
-
{
-  attribute:    '/data/attributes/%s'.freeze,
-  primary_data: '/data%s'.freeze
-}.freeze
- -
- - - - - - - - - -

- Class Method Summary - (collapse) -

- - - - - - -
-

Class Method Details

- - -
-

- - + (Object) new(pointer_type, value = nil) - - - - - -

- - - - -
-
-
-
-10
-11
-12
-
-
# File 'lib/active_model_serializers/json_pointer.rb', line 10
-
-def new(pointer_type, value = nil)
-  format(POINTERS[pointer_type], value)
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Jsonapi.html b/ActiveModelSerializers/Jsonapi.html deleted file mode 100644 index 0bb23d5f..00000000 --- a/ActiveModelSerializers/Jsonapi.html +++ /dev/null @@ -1,352 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Jsonapi - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Jsonapi - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model_serializers/register_jsonapi_renderer.rb
- -
-
- -

Overview

-
- -

Based on discussion in github.com/rails/rails/pull/23712#issuecomment-184977238, -the JSON API media type will have its own format/renderer.

- -

> We recommend the media type be registered on its own as jsonapi when a -jsonapi Renderer and deserializer (Http::Parameters::DEFAULT_PARSERS) are -added.

- -

Usage:

- -

ActiveSupport.on_load(:action_controller) do

- -
require 'active_model_serializers/register_jsonapi_renderer'
-
- -

end

- -

And then in controllers, use `render jsonapi: model` rather than `render -json: model, adapter: :json_api`.

- -

For example, in a controller action, we can: respond_to do |format|

- -
format.jsonapi { render jsonapi: model }
-
- -

end

- -

or

- -

render jsonapi: model

- -

No wrapper format needed as it does not apply (i.e. no `wrap_parameters -format: [jsonapi]`)

- - -
-
-
- - -

Defined Under Namespace

-

- - - Modules: ControllerSupport - - - - -

- -

Constant Summary

- -
- -
MEDIA_TYPE = - -
-
'application/vnd.api+json'.freeze
- -
HEADERS = - -
-
{
-  response: { 'CONTENT_TYPE'.freeze => MEDIA_TYPE },
-  request:  { 'ACCEPT'.freeze => MEDIA_TYPE }
-}.freeze
- -
- - - - - - - - - -

- Class Method Summary - (collapse) -

- - - - - - -
-

Class Method Details

- - -
-

- - + (Object) install - - - - - -

- - - - -
-
-
-
-32
-33
-34
-35
-36
-37
-38
-39
-40
-41
-42
-43
-44
-45
-46
-47
-48
-
-
# File 'lib/active_model_serializers/register_jsonapi_renderer.rb', line 32
-
-def self.install
-  # actionpack/lib/action_dispatch/http/mime_types.rb
-  Mime::Type.register MEDIA_TYPE, :jsonapi
-
-  if Rails::VERSION::MAJOR >= 5
-    ActionDispatch::Request.parameter_parsers[:jsonapi] = parser
-  else
-    ActionDispatch::ParamsParser::DEFAULT_PARSERS[Mime[:jsonapi]] = parser
-  end
-
-  # ref https://github.com/rails/rails/pull/21496
-  ActionController::Renderers.add :jsonapi do |json, options|
-    json = serialize_jsonapi(json, options).to_json(options) unless json.is_a?(String)
-    self.content_type ||= Mime[:jsonapi]
-    self.response_body = json
-  end
-end
-
-
- -
-

- - + (Object) parser - - - - - -

-
- -

Proposal: should actually deserialize the JSON API params to the hash -format expected by `ActiveModel::Serializers::JSON` -actionpack/lib/action_dispatch/http/parameters.rb

- - -
-
-
- - -
- - - - -
-
-
-
-53
-54
-55
-56
-57
-58
-59
-
-
# File 'lib/active_model_serializers/register_jsonapi_renderer.rb', line 53
-
-def self.parser
-  lambda do |body|
-    data = JSON.parse(body)
-    data = { :_json => data } unless data.is_a?(Hash)
-    data.with_indifferent_access
-  end
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Jsonapi/ControllerSupport.html b/ActiveModelSerializers/Jsonapi/ControllerSupport.html deleted file mode 100644 index 0f93e95d..00000000 --- a/ActiveModelSerializers/Jsonapi/ControllerSupport.html +++ /dev/null @@ -1,182 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Jsonapi::ControllerSupport - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Jsonapi::ControllerSupport - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model_serializers/register_jsonapi_renderer.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) serialize_jsonapi(json, options) - - - - - -

- - - - -
-
-
-
-62
-63
-64
-65
-66
-67
-68
-
-
# File 'lib/active_model_serializers/register_jsonapi_renderer.rb', line 62
-
-def serialize_jsonapi(json, options)
-  options[:adapter] = :json_api
-  options.fetch(:serialization_context) do
-    options[:serialization_context] = ActiveModelSerializers::SerializationContext.new(request)
-  end
-  get_serializer(json, options)
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/KeyTransform.html b/ActiveModelSerializers/KeyTransform.html deleted file mode 100644 index 8bf05a0e..00000000 --- a/ActiveModelSerializers/KeyTransform.html +++ /dev/null @@ -1,533 +0,0 @@ - - - - - - Module: ActiveModelSerializers::KeyTransform - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::KeyTransform - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model_serializers/key_transform.rb
- -
-
- - - - - - - - - -

- Class Method Summary - (collapse) -

- - - - - - -
-

Class Method Details

- - -
-

- - + (Object) camel(value) - - - - - -

-
- -

Transforms values to UpperCamelCase or PascalCase.

- -

@example:

- -
"some_key" => "SomeKey",
- - -
-
-
- - -

See Also:

- - -
- - - - -
-
-
-
-12
-13
-14
-15
-16
-17
-18
-19
-
-
# File 'lib/active_model_serializers/key_transform.rb', line 12
-
-def camel(value)
-  case value
-  when Hash then value.deep_transform_keys! { |key| camel(key) }
-  when Symbol then camel(value.to_s).to_sym
-  when String then value.underscore.camelize
-  else value
-  end
-end
-
-
- -
-

- - + (Object) camel_lower(value) - - - - - -

-
- -

Transforms values to camelCase.

- -

@example:

- -
"some_key" => "someKey",
- - -
-
-
- - -

See Also:

- - -
- - - - -
-
-
-
-26
-27
-28
-29
-30
-31
-32
-33
-
-
# File 'lib/active_model_serializers/key_transform.rb', line 26
-
-def camel_lower(value)
-  case value
-  when Hash then value.deep_transform_keys! { |key| camel_lower(key) }
-  when Symbol then camel_lower(value.to_s).to_sym
-  when String then value.underscore.camelize(:lower)
-  else value
-  end
-end
-
-
- -
-

- - + (Object) dash(value) - - - - - -

-
- -

Transforms values to dashed-case. This is the default case for the JsonApi -adapter.

- -

@example:

- -
"some_key" => "some-key",
- - -
-
-
- - -

See Also:

- - -
- - - - -
-
-
-
-41
-42
-43
-44
-45
-46
-47
-48
-
-
# File 'lib/active_model_serializers/key_transform.rb', line 41
-
-def dash(value)
-  case value
-  when Hash then value.deep_transform_keys! { |key| dash(key) }
-  when Symbol then dash(value.to_s).to_sym
-  when String then value.underscore.dasherize
-  else value
-  end
-end
-
-
- -
-

- - + (Object) unaltered(value) - - - - - -

-
- -

Returns the value unaltered

- - -
-
-
- - -
- - - - -
-
-
-
-66
-67
-68
-
-
# File 'lib/active_model_serializers/key_transform.rb', line 66
-
-def unaltered(value)
-  value
-end
-
-
- -
-

- - + (Object) underscore(value) - - - - - -

-
- -

Transforms values to underscore_case. This is the default case for -deserialization in the JsonApi adapter.

- -

@example:

- -
"some-key" => "some_key",
- - -
-
-
- - -

See Also:

- - -
- - - - -
-
-
-
-56
-57
-58
-59
-60
-61
-62
-63
-
-
# File 'lib/active_model_serializers/key_transform.rb', line 56
-
-def underscore(value)
-  case value
-  when Hash then value.deep_transform_keys! { |key| underscore(key) }
-  when Symbol then underscore(value.to_s).to_sym
-  when String then value.underscore
-  else value
-  end
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Logging.html b/ActiveModelSerializers/Logging.html deleted file mode 100644 index 13437190..00000000 --- a/ActiveModelSerializers/Logging.html +++ /dev/null @@ -1,271 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Logging - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Logging - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Concern
- - - - - - -
Included in:
-
SerializableResource
- - - -
Defined in:
-
lib/active_model_serializers/logging.rb
- -
-
- -

Defined Under Namespace

-

- - - Modules: ClassMethods, Macros - - - - Classes: LogSubscriber - - -

- -

Constant Summary

- -
- -
RENDER_EVENT = - -
-
'render.active_model_serializers'.freeze
- -
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) notify_render - - - - - -

- - - - -
-
-
-
-76
-77
-78
-79
-80
-81
-
-
# File 'lib/active_model_serializers/logging.rb', line 76
-
-def notify_render(*)
-  event_name = RENDER_EVENT
-  ActiveSupport::Notifications.instrument(event_name, notify_render_payload) do
-    yield
-  end
-end
-
-
- -
-

- - - (Object) notify_render_payload - - - - - -

- - - - -
-
-
-
-83
-84
-85
-86
-87
-88
-
-
# File 'lib/active_model_serializers/logging.rb', line 83
-
-def notify_render_payload
-  {
-    serializer: serializer || ActiveModel::Serializer::Null,
-    adapter: adapter || ActiveModelSerializers::Adapter::Null
-  }
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Logging/ClassMethods.html b/ActiveModelSerializers/Logging/ClassMethods.html deleted file mode 100644 index 9922f59e..00000000 --- a/ActiveModelSerializers/Logging/ClassMethods.html +++ /dev/null @@ -1,186 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Logging::ClassMethods - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Logging::ClassMethods - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model_serializers/logging.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) instrument_rendering - - - - - -

- - - - -
-
-
-
-18
-19
-20
-21
-22
-23
-24
-25
-26
-
-
# File 'lib/active_model_serializers/logging.rb', line 18
-
-def instrument_rendering
-  around_render do |args, block|
-    tag_logger do
-      notify_render do
-        block.call(args)
-      end
-    end
-  end
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Logging/LogSubscriber.html b/ActiveModelSerializers/Logging/LogSubscriber.html deleted file mode 100644 index 1dc85935..00000000 --- a/ActiveModelSerializers/Logging/LogSubscriber.html +++ /dev/null @@ -1,254 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Logging::LogSubscriber - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Logging::LogSubscriber - - - -

- -
- -
Inherits:
-
- ActiveSupport::LogSubscriber - -
    -
  • Object
  • - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/logging.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) logger - - - - - -

- - - - -
-
-
-
-115
-116
-117
-
-
# File 'lib/active_model_serializers/logging.rb', line 115
-
-def logger
-  ActiveModelSerializers.logger
-end
-
-
- -
-

- - - (Object) render(event) - - - - - -

- - - - -
-
-
-
-106
-107
-108
-109
-110
-111
-112
-113
-
-
# File 'lib/active_model_serializers/logging.rb', line 106
-
-def render(event)
-  info do
-    serializer = event.payload[:serializer]
-    adapter = event.payload[:adapter]
-    duration = event.duration.round(2)
-    "Rendered #{serializer.name} with #{adapter.class} (#{duration}ms)"
-  end
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Logging/Macros.html b/ActiveModelSerializers/Logging/Macros.html deleted file mode 100644 index 786dc46f..00000000 --- a/ActiveModelSerializers/Logging/Macros.html +++ /dev/null @@ -1,249 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Logging::Macros - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Logging::Macros - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model_serializers/logging.rb
- -
-
- -

Overview

-
- -

Macros that can be used to customize the logging of class or instance -methods, by extending the class or its singleton.

- -

Adapted from:

- -
https://github.com/rubygems/rubygems/blob/cb28f5e991/lib/rubygems/deprecate.rb
-
- -

Provides a single method notify to be used to declare when -something a method notifies, with the argument callback_name -of the notification callback.

- -
class Adapter
-  def self.klass_method
-    # ...
-  end
-
-  def instance_method
-    # ...
-  end
-
-  include ActiveModelSerializers::Logging::Macros
-  notify :instance_method, :render
-
-  class << self
-    extend ActiveModelSerializers::Logging::Macros
-    notify :klass_method, :render
-  end
-end
-
- - -
-
-
- - -
- - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) notify(name, callback_name) - - - - - -

-
- -

Simple notify method that wraps up name in a dummy method. It -notifies on with the callback_name notifier on each call to -the dummy method, telling what the current serializer and adapter are being -rendered. Adapted from:

- -
https://github.com/rubygems/rubygems/blob/cb28f5e991/lib/rubygems/deprecate.rb
-
- - -
-
-
- - -
- - - - -
-
-
-
-63
-64
-65
-66
-67
-68
-69
-70
-71
-72
-73
-
-
# File 'lib/active_model_serializers/logging.rb', line 63
-
-def notify(name, callback_name)
-  class_eval do
-    old = "_notifying_#{callback_name}_#{name}"
-    alias_method old, name
-    define_method name do |*args, &block|
-      run_callbacks callback_name do
-        send old, *args, &block
-      end
-    end
-  end
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Model.html b/ActiveModelSerializers/Model.html deleted file mode 100644 index d41aa838..00000000 --- a/ActiveModelSerializers/Model.html +++ /dev/null @@ -1,761 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Model - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Model - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - -
Includes:
-
ActiveModel::Model, ActiveModel::Serializers::JSON
- - - - - -
Defined in:
-
lib/active_model_serializers/model.rb
- -
-
- - - - - -

Instance Attribute Summary (collapse)

- - - - - - -

- Class Method Summary - (collapse) -

- - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Constructor Details

- -
-

- - - (Model) initialize(attributes = {}) - - - - - -

-
- -

Returns a new instance of Model

- - -
-
-
- - -
- - - - -
-
-
-
-11
-12
-13
-14
-15
-
-
# File 'lib/active_model_serializers/model.rb', line 11
-
-def initialize(attributes = {})
-  @attributes = attributes
-  @errors = ActiveModel::Errors.new(self)
-  super
-end
-
-
- -
- -
-

Instance Attribute Details

- - - -
-

- - - (Object) attributes (readonly) - - - - - -

-
- -

Returns the value of attribute attributes

- - -
-
-
- - -
- - - - -
-
-
-
-9
-10
-11
-
-
# File 'lib/active_model_serializers/model.rb', line 9
-
-def attributes
-  @attributes
-end
-
-
- - - -
-

- - - (Object) errors (readonly) - - - - - -

-
- -

Returns the value of attribute errors

- - -
-
-
- - -
- - - - -
-
-
-
-9
-10
-11
-
-
# File 'lib/active_model_serializers/model.rb', line 9
-
-def errors
-  @errors
-end
-
-
- -
- - -
-

Class Method Details

- - -
-

- - + (Object) human_attribute_name(attr, _options = {}) - - - - - -

-
- -

The following methods are needed to be minimally implemented for -ActiveModel::Errors :nocov:

- - -
-
-
- - -
- - - - -
-
-
-
-42
-43
-44
-
-
# File 'lib/active_model_serializers/model.rb', line 42
-
-def self.human_attribute_name(attr, _options = {})
-  attr
-end
-
-
- -
-

- - + (Object) lookup_ancestors - - - - - -

- - - - -
-
-
-
-46
-47
-48
-
-
# File 'lib/active_model_serializers/model.rb', line 46
-
-def self.lookup_ancestors
-  [self]
-end
-
-
- -
- -
-

Instance Method Details

- - -
-

- - - (Object) cache_key - - - - - -

-
- -

Defaults to the downcased model name and updated_at

- - -
-
-
- - -
- - - - -
-
-
-
-23
-24
-25
-
-
# File 'lib/active_model_serializers/model.rb', line 23
-
-def cache_key
-  attributes.fetch(:cache_key) { "#{self.class.name.downcase}/#{id}-#{updated_at.strftime("%Y%m%d%H%M%S%9N")}" }
-end
-
-
- -
-

- - - (Object) id - - - - - -

-
- -

Defaults to the downcased model name.

- - -
-
-
- - -
- - - - -
-
-
-
-18
-19
-20
-
-
# File 'lib/active_model_serializers/model.rb', line 18
-
-def id
-  attributes.fetch(:id) { self.class.name.downcase }
-end
-
-
- -
-

- - - (Object) read_attribute_for_serialization(key) - - - - - -

- - - - -
-
-
-
-32
-33
-34
-35
-36
-37
-38
-
-
# File 'lib/active_model_serializers/model.rb', line 32
-
-def read_attribute_for_serialization(key)
-  if key == :id || key == 'id'
-    attributes.fetch(key) { id }
-  else
-    attributes[key]
-  end
-end
-
-
- -
-

- - - (Object) updated_at - - - - - -

-
- -

Defaults to the time the serializer file was modified.

- - -
-
-
- - -
- - - - -
-
-
-
-28
-29
-30
-
-
# File 'lib/active_model_serializers/model.rb', line 28
-
-def updated_at
-  attributes.fetch(:updated_at) { File.mtime(__FILE__) }
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Railtie.html b/ActiveModelSerializers/Railtie.html deleted file mode 100644 index e119f9c5..00000000 --- a/ActiveModelSerializers/Railtie.html +++ /dev/null @@ -1,123 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Railtie - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Railtie - - - -

- -
- -
Inherits:
-
- Rails::Railtie - -
    -
  • Object
  • - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/railtie.rb
- -
-
- - - - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/SerializableResource.html b/ActiveModelSerializers/SerializableResource.html deleted file mode 100644 index 9b197470..00000000 --- a/ActiveModelSerializers/SerializableResource.html +++ /dev/null @@ -1,831 +0,0 @@ - - - - - - Class: ActiveModelSerializers::SerializableResource - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::SerializableResource - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - -
Includes:
-
Logging
- - - - - -
Defined in:
-
lib/active_model_serializers/serializable_resource.rb
- -
-
- - -

Constant Summary

- -
- -
ADAPTER_OPTION_KEYS = - -
-
Set.new([:include, :fields, :adapter, :meta, :meta_key, :links, :serialization_context, :key_transform])
- -
- - - - - - -

Constants included - from Logging

-

Logging::RENDER_EVENT

- - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods included from Logging

-

#notify_render, #notify_render_payload

- -
-

Constructor Details

- -
-

- - - (Object) initialize(resource, options = {}) - - - - - -

-
- -

Primary interface to composing a resource with a serializer and adapter.

- - -
-
-
- - -
- - - - -
-
-
-
-15
-16
-17
-18
-19
-
-
# File 'lib/active_model_serializers/serializable_resource.rb', line 15
-
-def initialize(resource, options = {})
-  @resource = resource
-  @adapter_opts, @serializer_opts =
-    options.partition { |k, _| ADAPTER_OPTION_KEYS.include? k }.map { |h| Hash[h] }
-end
-
-
- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) adapter - - - - Also known as: - adapter_instance - - - - -

-
- -

NOTE: if no adapter is available, returns the resource itself. (i.e. -adapter is a no-op)

- - -
-
-
- - -
- - - - -
-
-
-
-34
-35
-36
-
-
# File 'lib/active_model_serializers/serializable_resource.rb', line 34
-
-def adapter
-  @adapter ||= find_adapter
-end
-
-
- -
-

- - - (Object) find_adapter - - - - - -

- - - - -
-
-
-
-39
-40
-41
-42
-43
-44
-
-
# File 'lib/active_model_serializers/serializable_resource.rb', line 39
-
-def find_adapter
-  return resource unless serializer?
-  ActiveModelSerializers::Adapter.create(serializer_instance, adapter_opts)
-rescue ActiveModel::Serializer::CollectionSerializer::NoSerializerError
-  resource
-end
-
-
- -
-

- - - (Object) serialization_scope - - - - - -

- - - - -
-
-
-
-25
-26
-27
-
-
# File 'lib/active_model_serializers/serializable_resource.rb', line 25
-
-def serialization_scope
-  serializer_opts[:scope]
-end
-
-
- -
-

- - - (Object) serialization_scope=(scope) - - - - - -

- - - - -
-
-
-
-21
-22
-23
-
-
# File 'lib/active_model_serializers/serializable_resource.rb', line 21
-
-def serialization_scope=(scope)
-  serializer_opts[:scope] = scope
-end
-
-
- -
-

- - - (Object) serialization_scope_name=(scope_name) - - - - - -

- - - - -
-
-
-
-29
-30
-31
-
-
# File 'lib/active_model_serializers/serializable_resource.rb', line 29
-
-def serialization_scope_name=(scope_name)
-  serializer_opts[:scope_name] = scope_name
-end
-
-
- -
-

- - - (Object) serializer - - - - Also known as: - serializer_class - - - - -

-
- -

Get serializer either explicitly :serializer or implicitly from resource -Remove :serializer key from serializer_opts Replace :serializer key with -:each_serializer if present

- - -
-
-
- - -
- - - - -
-
-
-
-53
-54
-55
-56
-57
-58
-59
-60
-61
-62
-63
-64
-
-
# File 'lib/active_model_serializers/serializable_resource.rb', line 53
-
-def serializer
-  @serializer ||=
-    begin
-      @serializer = serializer_opts.delete(:serializer)
-      @serializer ||= ActiveModel::Serializer.serializer_for(resource)
-
-      if serializer_opts.key?(:each_serializer)
-        serializer_opts[:serializer] = serializer_opts.delete(:each_serializer)
-      end
-      @serializer
-    end
-end
-
-
- -
-

- - - (Boolean) serializer? - - - - - -

-
- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-73
-74
-75
-
-
# File 'lib/active_model_serializers/serializable_resource.rb', line 73
-
-def serializer?
-  use_adapter? && !serializer.nil?
-end
-
-
- -
-

- - - (Object) serializer_instance - - - - - -

- - - - -
-
-
-
-46
-47
-48
-
-
# File 'lib/active_model_serializers/serializable_resource.rb', line 46
-
-def serializer_instance
-  @serializer_instance ||= serializer.new(resource, serializer_opts)
-end
-
-
- -
-

- - - (Boolean) use_adapter? - - - - - -

-
- -

True when no explicit adapter given, or explicit appear is truthy (non-nil) -False when explicit adapter is falsy (nil or false)

- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-69
-70
-71
-
-
# File 'lib/active_model_serializers/serializable_resource.rb', line 69
-
-def use_adapter?
-  !(adapter_opts.key?(:adapter) && !adapter_opts[:adapter])
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/SerializationContext.html b/ActiveModelSerializers/SerializationContext.html deleted file mode 100644 index 6e9a7368..00000000 --- a/ActiveModelSerializers/SerializationContext.html +++ /dev/null @@ -1,568 +0,0 @@ - - - - - - Class: ActiveModelSerializers::SerializationContext - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::SerializationContext - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/serialization_context.rb
- -
-
- -

Defined Under Namespace

-

- - - Modules: UrlHelpers - - - - -

- - - - -

Class Attribute Summary (collapse)

- - -

Instance Attribute Summary (collapse)

- - - - - - -

- Instance Method Summary - (collapse) -

- - - - -
-

Constructor Details

- -
-

- - - (SerializationContext) initialize(request, options = {}) - - - - - -

-
- -

Returns a new instance of SerializationContext

- - -
-
-
- - -
- - - - -
-
-
-
-25
-26
-27
-28
-29
-30
-
-
# File 'lib/active_model_serializers/serialization_context.rb', line 25
-
-def initialize(request, options = {})
-  @request_url = request.original_url[/\A[^?]+/]
-  @query_parameters = request.query_parameters
-  @url_helpers = options.delete(:url_helpers) || self.class.url_helpers
-  @default_url_options = options.delete(:default_url_options) || self.class.default_url_options
-end
-
-
- -
- -
-

Class Attribute Details

- - - -
-

- - + (Object) default_url_options - - - - - -

- - - - -
-
-
-
-9
-10
-11
-
-
# File 'lib/active_model_serializers/serialization_context.rb', line 9
-
-def default_url_options
-  @default_url_options ||= {}
-end
-
-
- - - -
-

- - + (Object) url_helpers - - - - - -

- - - - -
-
-
-
-5
-6
-7
-
-
# File 'lib/active_model_serializers/serialization_context.rb', line 5
-
-def url_helpers
-  @url_helpers ||= Module.new
-end
-
-
- -
- -
-

Instance Attribute Details

- - - -
-

- - - (Object) key_transform (readonly) - - - - - -

-
- -

Returns the value of attribute key_transform

- - -
-
-
- - -
- - - - -
-
-
-
-23
-24
-25
-
-
# File 'lib/active_model_serializers/serialization_context.rb', line 23
-
-def key_transform
-  @key_transform
-end
-
-
- - - -
-

- - - (Object) query_parameters (readonly) - - - - - -

-
- -

Returns the value of attribute query_parameters

- - -
-
-
- - -
- - - - -
-
-
-
-23
-24
-25
-
-
# File 'lib/active_model_serializers/serialization_context.rb', line 23
-
-def query_parameters
-  @query_parameters
-end
-
-
- - - -
-

- - - (Object) request_url (readonly) - - - - - -

-
- -

Returns the value of attribute request_url

- - -
-
-
- - -
- - - - -
-
-
-
-23
-24
-25
-
-
# File 'lib/active_model_serializers/serialization_context.rb', line 23
-
-def request_url
-  @request_url
-end
-
-
- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/SerializationContext/UrlHelpers.html b/ActiveModelSerializers/SerializationContext/UrlHelpers.html deleted file mode 100644 index 48e04cb9..00000000 --- a/ActiveModelSerializers/SerializationContext/UrlHelpers.html +++ /dev/null @@ -1,245 +0,0 @@ - - - - - - Module: ActiveModelSerializers::SerializationContext::UrlHelpers - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::SerializationContext::UrlHelpers - - - -

- -
- - - - - - - -
Included in:
-
Adapter::JsonApi::Link
- - - -
Defined in:
-
lib/active_model_serializers/serialization_context.rb
- -
-
- - - - - - - - - -

- Class Method Summary - (collapse) -

- - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Class Method Details

- - -
-

- - + (Object) included(base) - - - - - -

- - - - -
-
-
-
-14
-15
-16
-
-
# File 'lib/active_model_serializers/serialization_context.rb', line 14
-
-def self.included(base)
-  base.send(:include, SerializationContext.url_helpers)
-end
-
-
- -
- -
-

Instance Method Details

- - -
-

- - - (Object) default_url_options - - - - - -

- - - - -
-
-
-
-18
-19
-20
-
-
# File 'lib/active_model_serializers/serialization_context.rb', line 18
-
-def default_url_options
-  SerializationContext.default_url_options
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Test.html b/ActiveModelSerializers/Test.html deleted file mode 100644 index fe457856..00000000 --- a/ActiveModelSerializers/Test.html +++ /dev/null @@ -1,122 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Test - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Test - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Autoload
- - - - - - - -
Defined in:
-
lib/active_model_serializers/test.rb,
- lib/active_model_serializers/test/schema.rb,
lib/active_model_serializers/test/serializer.rb
-
- -
-
- -

Defined Under Namespace

-

- - - Modules: Schema, Serializer - - - - -

- - - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Test/Schema.html b/ActiveModelSerializers/Test/Schema.html deleted file mode 100644 index 667730f4..00000000 --- a/ActiveModelSerializers/Test/Schema.html +++ /dev/null @@ -1,472 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Test::Schema - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Test::Schema - - - -

- -
- - - - - - - - -
Defined in:
-
lib/active_model_serializers/test/schema.rb
- -
-
- -

Defined Under Namespace

-

- - - - - Classes: AssertRequestSchema, AssertResponseSchema, AssertSchema - - -

- -

Constant Summary

- -
- -
MissingSchema = - -
-
Class.new(Minitest::Assertion)
- -
InvalidSchemaError = - -
-
Class.new(Minitest::Assertion)
- -
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) assert_request_response_schema(schema_path = nil, message = nil) - - - - - -

-
- -

May be renamed

- - -
-
-
- - -
- - - - -
-
-
-
-23
-24
-25
-26
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 23
-
-def assert_request_response_schema(schema_path = nil, message = nil)
-  assert_request_schema(schema_path, message)
-  assert_response_schema(schema_path, message)
-end
-
-
- -
-

- - - (Object) assert_request_schema(schema_path = nil, message = nil) - - - - - -

- - - - -
-
-
-
-17
-18
-19
-20
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 17
-
-def assert_request_schema(schema_path = nil, message = nil)
-  matcher = AssertRequestSchema.new(schema_path, request, response, message)
-  assert(matcher.call, matcher.message)
-end
-
-
- -
-

- - - (Boolean, Minitest::Assertion) assert_response_schema(schema_path = nil, message = nil) - - - - - -

-
- -

A Minitest Assertion that test the response is valid against a schema.

- - -
-
-
- -
-

Examples:

- - -
get :index
-assert_response_schema
- -
-

Parameters:

-
    - -
  • - - schema_path - - - (String) - - - (defaults to: nil) - - - — -
    -

    a custom schema path

    -
    - -
  • - -
  • - - message - - - (String) - - - (defaults to: nil) - - - — -
    -

    a custom error message

    -
    - -
  • - -
- -

Returns:

-
    - -
  • - - - (Boolean) - - - - — -
    -

    true when the response is valid

    -
    - -
  • - -
  • - - - (Minitest::Assertion) - - - - — -
    -

    when the response is invalid

    -
    - -
  • - -
- -
- - - - -
-
-
-
-12
-13
-14
-15
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 12
-
-def assert_response_schema(schema_path = nil, message = nil)
-  matcher = AssertResponseSchema.new(schema_path, request, response, message)
-  assert(matcher.call, matcher.message)
-end
-
-
- -
-

- - - (Object) assert_schema(payload, schema_path = nil, message = nil) - - - - - -

- - - - -
-
-
-
-28
-29
-30
-31
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 28
-
-def assert_schema(payload, schema_path = nil, message = nil)
-  matcher = AssertSchema.new(schema_path, request, response, message, payload)
-  assert(matcher.call, matcher.message)
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Test/Schema/AssertRequestSchema.html b/ActiveModelSerializers/Test/Schema/AssertRequestSchema.html deleted file mode 100644 index 259c22ab..00000000 --- a/ActiveModelSerializers/Test/Schema/AssertRequestSchema.html +++ /dev/null @@ -1,222 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Test::Schema::AssertRequestSchema - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Test::Schema::AssertRequestSchema - - - -

- -
- -
Inherits:
-
- AssertSchema - -
    -
  • Object
  • - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/test/schema.rb
- -
-
- - - - - - - -

Instance Attribute Summary

- -

Attributes inherited from AssertSchema

-

#message, #payload, #request, #response, #schema_path

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods inherited from AssertSchema

-

#call

-
-

Constructor Details

- -
-

- - - (AssertRequestSchema) initialize - - - - - -

-
- -

Returns a new instance of AssertRequestSchema

- - -
-
-
- - -
- - - - -
-
-
-
-131
-132
-133
-134
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 131
-
-def initialize(*)
-  super
-  @payload = request_params
-end
-
-
- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Test/Schema/AssertResponseSchema.html b/ActiveModelSerializers/Test/Schema/AssertResponseSchema.html deleted file mode 100644 index 8c4827c6..00000000 --- a/ActiveModelSerializers/Test/Schema/AssertResponseSchema.html +++ /dev/null @@ -1,222 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Test::Schema::AssertResponseSchema - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Test::Schema::AssertResponseSchema - - - -

- -
- -
Inherits:
-
- AssertSchema - -
    -
  • Object
  • - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/test/schema.rb
- -
-
- - - - - - - -

Instance Attribute Summary

- -

Attributes inherited from AssertSchema

-

#message, #payload, #request, #response, #schema_path

- - - -

- Instance Method Summary - (collapse) -

- - - - - - - - - - - - - -

Methods inherited from AssertSchema

-

#call

-
-

Constructor Details

- -
-

- - - (AssertResponseSchema) initialize - - - - - -

-
- -

Returns a new instance of AssertResponseSchema

- - -
-
-
- - -
- - - - -
-
-
-
-125
-126
-127
-128
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 125
-
-def initialize(*)
-  super
-  @payload = response_body
-end
-
-
- -
- - -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Test/Schema/AssertSchema.html b/ActiveModelSerializers/Test/Schema/AssertSchema.html deleted file mode 100644 index 2c6a7308..00000000 --- a/ActiveModelSerializers/Test/Schema/AssertSchema.html +++ /dev/null @@ -1,654 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Test::Schema::AssertSchema - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Test::Schema::AssertSchema - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/test/schema.rb
- -
-
- -
-

Direct Known Subclasses

-

AssertRequestSchema, AssertResponseSchema

-
- - - - -

Instance Attribute Summary (collapse)

- - - - - - -

- Instance Method Summary - (collapse) -

- - - - -
-

Constructor Details

- -
-

- - - (AssertSchema) initialize(schema_path, request, response, message, payload = nil) - - - - - -

-
- -

Interface may change.

- - -
-
-
- - -
- - - - -
-
-
-
-40
-41
-42
-43
-44
-45
-46
-47
-48
-49
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 40
-
-def initialize(schema_path, request, response, message, payload = nil)
-  require_json_schema!
-  @request = request
-  @response = response
-  @payload = payload
-  @schema_path = schema_path || schema_path_default
-  @message = message
-  @document_store = JsonSchema::DocumentStore.new
-  add_schema_to_document_store
-end
-
-
- -
- -
-

Instance Attribute Details

- - - -
-

- - - (Object) message (readonly) - - - - - -

-
- -

Returns the value of attribute message

- - -
-
-
- - -
- - - - -
-
-
-
-37
-38
-39
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 37
-
-def message
-  @message
-end
-
-
- - - -
-

- - - (Object) payload (readonly) - - - - - -

-
- -

Returns the value of attribute payload

- - -
-
-
- - -
- - - - -
-
-
-
-37
-38
-39
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 37
-
-def payload
-  @payload
-end
-
-
- - - -
-

- - - (Object) request (readonly) - - - - - -

-
- -

Returns the value of attribute request

- - -
-
-
- - -
- - - - -
-
-
-
-37
-38
-39
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 37
-
-def request
-  @request
-end
-
-
- - - -
-

- - - (Object) response (readonly) - - - - - -

-
- -

Returns the value of attribute response

- - -
-
-
- - -
- - - - -
-
-
-
-37
-38
-39
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 37
-
-def response
-  @response
-end
-
-
- - - -
-

- - - (Object) schema_path (readonly) - - - - - -

-
- -

Returns the value of attribute schema_path

- - -
-
-
- - -
- - - - -
-
-
-
-37
-38
-39
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 37
-
-def schema_path
-  @schema_path
-end
-
-
- -
- - -
-

Instance Method Details

- - -
-

- - - (Object) call - - - - - -

- - - - -
-
-
-
-51
-52
-53
-54
-55
-56
-
-
# File 'lib/active_model_serializers/test/schema.rb', line 51
-
-def call
-  json_schema.expand_references!(store: document_store)
-  status, errors = json_schema.validate(response_body)
-  @message = [message, errors.map(&:to_s).to_sentence].compact.join(': ')
-  status
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Test/Serializer.html b/ActiveModelSerializers/Test/Serializer.html deleted file mode 100644 index 99f418ac..00000000 --- a/ActiveModelSerializers/Test/Serializer.html +++ /dev/null @@ -1,227 +0,0 @@ - - - - - - Module: ActiveModelSerializers::Test::Serializer - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: ActiveModelSerializers::Test::Serializer - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Concern
- - - - - - - -
Defined in:
-
lib/active_model_serializers/test/serializer.rb
- -
-
- -

Defined Under Namespace

-

- - - - - Classes: AssertSerializer - - -

- - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) assert_serializer(expectation, message = nil) - - - - - -

-
- -

Asserts that the request was rendered with the appropriate serializers.

- -
# assert that the "PostSerializer" serializer was rendered
-assert_serializer "PostSerializer"
-
-# return a custom error message
-assert_serializer "PostSerializer", "PostSerializer not rendered"
-
-# assert that the instance of PostSerializer was rendered
-assert_serializer PostSerializer
-
-# assert that the "PostSerializer" serializer was rendered
-assert_serializer :post_serializer
-
-# assert that the rendered serializer starts with "Post"
-assert_serializer %r{\APost.+\Z}
-
-# assert that no serializer was rendered
-assert_serializer nil
-
- - -
-
-
- - -
- - - - -
-
-
-
-32
-33
-34
-35
-36
-37
-
-
# File 'lib/active_model_serializers/test/serializer.rb', line 32
-
-def assert_serializer(expectation, message = nil)
-  @assert_serializer.expectation = expectation
-  @assert_serializer.message = message
-  @assert_serializer.response = response
-  assert(@assert_serializer.matches?, @assert_serializer.message)
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/ActiveModelSerializers/Test/Serializer/AssertSerializer.html b/ActiveModelSerializers/Test/Serializer/AssertSerializer.html deleted file mode 100644 index 75ddbf8e..00000000 --- a/ActiveModelSerializers/Test/Serializer/AssertSerializer.html +++ /dev/null @@ -1,710 +0,0 @@ - - - - - - Class: ActiveModelSerializers::Test::Serializer::AssertSerializer - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: ActiveModelSerializers::Test::Serializer::AssertSerializer - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/active_model_serializers/test/serializer.rb
- -
-
- - - - - -

Instance Attribute Summary (collapse)

- - - - - - -

- Instance Method Summary - (collapse) -

- - - - -
-

Constructor Details

- -
-

- - - (AssertSerializer) initialize - - - - - -

-
- -

Returns a new instance of AssertSerializer

- - -
-
-
- - -
- - - - -
-
-
-
-43
-44
-45
-46
-
-
# File 'lib/active_model_serializers/test/serializer.rb', line 43
-
-def initialize
-  @serializers = Set.new
-  @_subscribers = []
-end
-
-
- -
- -
-

Instance Attribute Details

- - - -
-

- - - (Object) expectation - - - - - -

-
- -

Returns the value of attribute expectation

- - -
-
-
- - -
- - - - -
-
-
-
-41
-42
-43
-
-
# File 'lib/active_model_serializers/test/serializer.rb', line 41
-
-def expectation
-  @expectation
-end
-
-
- - - -
-

- - - (Object) message - - - - - -

-
- -

Returns the value of attribute message

- - -
-
-
- - -
- - - - -
-
-
-
-40
-41
-42
-
-
# File 'lib/active_model_serializers/test/serializer.rb', line 40
-
-def message
-  @message
-end
-
-
- - - -
-

- - - (Object) response - - - - - -

-
- -

Returns the value of attribute response

- - -
-
-
- - -
- - - - -
-
-
-
-41
-42
-43
-
-
# File 'lib/active_model_serializers/test/serializer.rb', line 41
-
-def response
-  @response
-end
-
-
- - - -
-

- - - (Object) serializers (readonly) - - - - - -

-
- -

Returns the value of attribute serializers

- - -
-
-
- - -
- - - - -
-
-
-
-40
-41
-42
-
-
# File 'lib/active_model_serializers/test/serializer.rb', line 40
-
-def serializers
-  @serializers
-end
-
-
- -
- - -
-

Instance Method Details

- - -
-

- - - (Boolean) matches? - - - - - -

-
- - -
-
-
- -

Returns:

-
    - -
  • - - - (Boolean) - - - -
  • - -
- -
- - - - -
-
-
-
-52
-53
-54
-55
-56
-57
-58
-59
-60
-61
-62
-63
-64
-
-
# File 'lib/active_model_serializers/test/serializer.rb', line 52
-
-def matches?
-  # Force body to be read in case the template is being streamed.
-  response.body
-
-  case expectation
-  when a_serializer? then matches_class?
-  when Symbol        then matches_symbol?
-  when String        then matches_string?
-  when Regexp        then matches_regexp?
-  when NilClass      then matches_nil?
-  else fail ArgumentError, 'assert_serializer only accepts a String, Symbol, Regexp, ActiveModel::Serializer, or nil'
-  end
-end
-
-
- -
-

- - - (Object) subscribe - - - - - -

- - - - -
-
-
-
-66
-67
-68
-69
-70
-71
-
-
# File 'lib/active_model_serializers/test/serializer.rb', line 66
-
-def subscribe
-  @_subscribers << ActiveSupport::Notifications.subscribe(event_name) do |_name, _start, _finish, _id, payload|
-    serializer = payload[:serializer].name
-    serializers << serializer
-  end
-end
-
-
- -
-

- - - (Object) unsubscribe - - - - - -

- - - - -
-
-
-
-73
-74
-75
-76
-77
-
-
# File 'lib/active_model_serializers/test/serializer.rb', line 73
-
-def unsubscribe
-  @_subscribers.each do |subscriber|
-    ActiveSupport::Notifications.unsubscribe(subscriber)
-  end
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/Grape.html b/Grape.html deleted file mode 100644 index 36d79693..00000000 --- a/Grape.html +++ /dev/null @@ -1,133 +0,0 @@ - - - - - - Module: Grape - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: Grape - - - -

- -
- - - - - - - - -
Defined in:
-
lib/grape/helpers/active_model_serializers.rb,
- lib/grape/formatters/active_model_serializers.rb
-
- -
-
- -

Overview

-
- -

A Grape response formatter that can be used as 'formatter :json, -Grape::Formatters::ActiveModelSerializers'

- -

Serializer options can be passed as a hash from your Grape endpoint using -env, or better yet user the -render helper in Grape::Helpers::ActiveModelSerializers

- - -
-
-
- - -

Defined Under Namespace

-

- - - Modules: ActiveModelSerializers, Formatters, Helpers - - - - -

- - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/Grape/ActiveModelSerializers.html b/Grape/ActiveModelSerializers.html deleted file mode 100644 index f682158b..00000000 --- a/Grape/ActiveModelSerializers.html +++ /dev/null @@ -1,110 +0,0 @@ - - - - - - Module: Grape::ActiveModelSerializers - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: Grape::ActiveModelSerializers - - - -

- -
- - - -
Extended by:
-
ActiveSupport::Concern
- - - - - - - -
Defined in:
-
lib/grape/active_model_serializers.rb
- -
-
- - - - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/Grape/Formatters.html b/Grape/Formatters.html deleted file mode 100644 index fc8d867d..00000000 --- a/Grape/Formatters.html +++ /dev/null @@ -1,115 +0,0 @@ - - - - - - Module: Grape::Formatters - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: Grape::Formatters - - - -

- -
- - - - - - - - -
Defined in:
-
lib/grape/formatters/active_model_serializers.rb
- -
-
- -

Defined Under Namespace

-

- - - Modules: ActiveModelSerializers - - - - -

- - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/Grape/Formatters/ActiveModelSerializers.html b/Grape/Formatters/ActiveModelSerializers.html deleted file mode 100644 index 4698f5c7..00000000 --- a/Grape/Formatters/ActiveModelSerializers.html +++ /dev/null @@ -1,178 +0,0 @@ - - - - - - Module: Grape::Formatters::ActiveModelSerializers - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: Grape::Formatters::ActiveModelSerializers - - - -

- -
- - - - - - - - -
Defined in:
-
lib/grape/formatters/active_model_serializers.rb
- -
-
- - - - - - - - - -

- Class Method Summary - (collapse) -

- - - - - - -
-

Class Method Details

- - -
-

- - + (Object) call(resource, env) - - - - - -

- - - - -
-
-
-
-8
-9
-10
-11
-12
-
-
# File 'lib/grape/formatters/active_model_serializers.rb', line 8
-
-def self.call(resource, env)
-  serializer_options = {}
-  serializer_options.merge!(env[:active_model_serializer_options]) if env[:active_model_serializer_options]
-  ::ActiveModelSerializers::SerializableResource.new(resource, serializer_options).to_json
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/Grape/Helpers.html b/Grape/Helpers.html deleted file mode 100644 index 9fbf4f07..00000000 --- a/Grape/Helpers.html +++ /dev/null @@ -1,115 +0,0 @@ - - - - - - Module: Grape::Helpers - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: Grape::Helpers - - - -

- -
- - - - - - - - -
Defined in:
-
lib/grape/helpers/active_model_serializers.rb
- -
-
- -

Defined Under Namespace

-

- - - Modules: ActiveModelSerializers - - - - -

- - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/Grape/Helpers/ActiveModelSerializers.html b/Grape/Helpers/ActiveModelSerializers.html deleted file mode 100644 index 59b374cf..00000000 --- a/Grape/Helpers/ActiveModelSerializers.html +++ /dev/null @@ -1,195 +0,0 @@ - - - - - - Module: Grape::Helpers::ActiveModelSerializers - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: Grape::Helpers::ActiveModelSerializers - - - -

- -
- - - - - - - - -
Defined in:
-
lib/grape/helpers/active_model_serializers.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) render(resource, active_model_serializer_options = {}) - - - - - -

-
- -

A convenience method for passing ActiveModelSerializers serializer options

- -

Example: To include relationships in the response: render(post, include: -['comments'])

- -

Example: To include pagination meta data: render(posts, meta: { page: -posts.page, total_pages: posts.total_pages })

- - -
-
-
- - -
- - - - -
-
-
-
-10
-11
-12
-13
-
-
# File 'lib/grape/helpers/active_model_serializers.rb', line 10
-
-def render(resource, active_model_serializer_options = {})
-  env[:active_model_serializer_options] = active_model_serializer_options
-  resource
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/Rails.html b/Rails.html deleted file mode 100644 index 1363a2ae..00000000 --- a/Rails.html +++ /dev/null @@ -1,117 +0,0 @@ - - - - - - Module: Rails - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: Rails - - - -

- -
- - - - - - - - -
Defined in:
-
lib/generators/rails/resource_override.rb,
- lib/generators/rails/serializer_generator.rb
-
- -
-
- -

Defined Under Namespace

-

- - - Modules: Generators - - - - -

- - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/Rails/Generators.html b/Rails/Generators.html deleted file mode 100644 index dac7c09c..00000000 --- a/Rails/Generators.html +++ /dev/null @@ -1,117 +0,0 @@ - - - - - - Module: Rails::Generators - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Module: Rails::Generators - - - -

- -
- - - - - - - - -
Defined in:
-
lib/generators/rails/resource_override.rb,
- lib/generators/rails/serializer_generator.rb
-
- -
-
- -

Defined Under Namespace

-

- - - - - Classes: ResourceGenerator, SerializerGenerator - - -

- - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/Rails/Generators/ResourceGenerator.html b/Rails/Generators/ResourceGenerator.html deleted file mode 100644 index 0843ec17..00000000 --- a/Rails/Generators/ResourceGenerator.html +++ /dev/null @@ -1,120 +0,0 @@ - - - - - - Class: Rails::Generators::ResourceGenerator - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: Rails::Generators::ResourceGenerator - - - -

- -
- -
Inherits:
-
- Object - -
    -
  • Object
  • - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/generators/rails/resource_override.rb
- -
-
- - - - - - - - - - -
- - - - - \ No newline at end of file diff --git a/Rails/Generators/SerializerGenerator.html b/Rails/Generators/SerializerGenerator.html deleted file mode 100644 index 74954b4b..00000000 --- a/Rails/Generators/SerializerGenerator.html +++ /dev/null @@ -1,192 +0,0 @@ - - - - - - Class: Rails::Generators::SerializerGenerator - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Class: Rails::Generators::SerializerGenerator - - - -

- -
- -
Inherits:
-
- NamedBase - -
    -
  • Object
  • - - - - - -
- show all - -
- - - - - - - - - -
Defined in:
-
lib/generators/rails/serializer_generator.rb
- -
-
- - - - - - - - - -

- Instance Method Summary - (collapse) -

- - - - - - - -
-

Instance Method Details

- - -
-

- - - (Object) create_serializer_file - - - - - -

- - - - -
-
-
-
-11
-12
-13
-
-
# File 'lib/generators/rails/serializer_generator.rb', line 11
-
-def create_serializer_file
-  template 'serializer.rb.erb', File.join('app/serializers', class_path, "#{file_name}_serializer.rb")
-end
-
-
- -
- -
- - - - - \ No newline at end of file diff --git a/_index.html b/_index.html deleted file mode 100644 index fc58c61e..00000000 --- a/_index.html +++ /dev/null @@ -1,874 +0,0 @@ - - - - - - Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -

Documentation by YARD 0.8.7.6

-
-

Alphabetic Index

- -

File Listing

- - -
-

Namespace Listing A-Z

- - - - - - - - -
- - - - - -
    -
  • B
  • -
      - -
    • - Base - - (ActiveModel::Serializer::Adapter) - -
    • - -
    • - Base - - (ActiveModelSerializers::Adapter) - -
    • - -
    • - BelongsToReflection - - (ActiveModel::Serializer) - -
    • - -
    -
- - - - - - - - -
    -
  • E
  • -
      - -
    • - Error - - (ActiveModelSerializers::Adapter::JsonApi) - -
    • - -
    • - ErrorSerializer - - (ActiveModel::Serializer) - -
    • - -
    • - ErrorsSerializer - - (ActiveModel::Serializer) - -
    • - -
    -
- - -
    -
  • F
  • -
      - -
    • - Field - - (ActiveModel::Serializer) - -
    • - -
    • - Fieldset - - (ActiveModel::Serializer) - -
    • - -
    • - Formatters - - (Grape) - -
    • - -
    -
- - - - - -
- - - - - -
    -
  • J
  • -
      - -
    • - Json - - (ActiveModel::Serializer::Adapter) - -
    • - -
    • - Json - - (ActiveModelSerializers::Adapter) - -
    • - -
    • - JsonApi - - (ActiveModel::Serializer::Adapter) - -
    • - -
    • - JsonApi - - (ActiveModelSerializers::Adapter) - -
    • - -
    • - JsonPointer - - (ActiveModelSerializers) - -
    • - -
    • - Jsonapi - - (ActiveModelSerializers) - -
    • - -
    • - Jsonapi - - (ActiveModelSerializers::Adapter::JsonApi) - -
    • - -
    -
- - -
    -
  • K
  • - -
- - -
    -
  • L
  • -
      - -
    • - Link - - (ActiveModelSerializers::Adapter::JsonApi) - -
    • - -
    • - Links - - (ActiveModel::Serializer) - -
    • - -
    • - Lint - - (ActiveModel::Serializer) - -
    • - -
    • - LogSubscriber - - (ActiveModelSerializers::Logging) - -
    • - -
    • - Logging - - (ActiveModelSerializers) - -
    • - -
    -
- - -
    -
  • M
  • -
      - -
    • - Macros - - (ActiveModelSerializers::Logging) - -
    • - -
    • - Meta - - (ActiveModelSerializers::Adapter::JsonApi) - -
    • - -
    • - Meta - - (ActiveModel::Serializer) - -
    • - -
    • - Model - - (ActiveModelSerializers) - -
    • - -
    -
- - -
    -
  • N
  • -
      - -
    • - Null - - (ActiveModelSerializers::Adapter) - -
    • - -
    • - Null - - (ActiveModel::Serializer::Adapter) - -
    • - -
    • - Null - - (ActiveModel::Serializer) - -
    • - -
    -
- - -
    -
  • P
  • -
      - -
    • - PaginationLinks - - (ActiveModelSerializers::Adapter::JsonApi) - -
    • - -
    -
- - - - - -
- - - - - -
    -
  • T
  • -
      - -
    • - Test - - (ActiveModelSerializers) - -
    • - -
    • - Tests - - (ActiveModel::Serializer::Lint) - -
    • - -
    • - Type - - (ActiveModel::Serializer) - -
    • - -
    -
- - -
    -
  • U
  • -
      - -
    • - UrlHelpers - - (ActiveModelSerializers::SerializationContext) - -
    • - -
    -
- -
- -
- -
- - - - - \ No newline at end of file diff --git a/class_list.html b/class_list.html deleted file mode 100644 index 43b21b90..00000000 --- a/class_list.html +++ /dev/null @@ -1,58 +0,0 @@ - - - - - - - - - - - - - - - - - Class List - - - - -
-

Class List

- - - - -
- - diff --git a/css/common.css b/css/common.css deleted file mode 100644 index cf25c452..00000000 --- a/css/common.css +++ /dev/null @@ -1 +0,0 @@ -/* Override this file with custom rules */ \ No newline at end of file diff --git a/css/full_list.css b/css/full_list.css deleted file mode 100644 index c918cf19..00000000 --- a/css/full_list.css +++ /dev/null @@ -1,57 +0,0 @@ -body { - margin: 0; - font-family: "Lucida Sans", "Lucida Grande", Verdana, Arial, sans-serif; - font-size: 13px; - height: 101%; - overflow-x: hidden; -} - -h1 { padding: 12px 10px; padding-bottom: 0; margin: 0; font-size: 1.4em; } -.clear { clear: both; } -#search { position: absolute; right: 5px; top: 9px; padding-left: 24px; } -#content.insearch #search, #content.insearch #noresults { background: url() no-repeat center left; } -#full_list { padding: 0; list-style: none; margin-left: 0; } -#full_list ul { padding: 0; } -#full_list li { padding: 5px; padding-left: 12px; margin: 0; font-size: 1.1em; list-style: none; } -#noresults { padding: 7px 12px; } -#content.insearch #noresults { margin-left: 7px; } -ul.collapsed ul, ul.collapsed li { display: none; } -ul.collapsed.search_uncollapsed { display: block; } -ul.collapsed.search_uncollapsed li { display: list-item; } -li a.toggle { cursor: default; position: relative; left: -5px; top: 4px; text-indent: -999px; width: 10px; height: 9px; margin-left: -10px; display: block; float: left; background: url() no-repeat bottom left; } -li.collapsed a.toggle { opacity: 0.5; cursor: default; background-position: top left; } -li { color: #888; cursor: pointer; } -li.deprecated { text-decoration: line-through; font-style: italic; } -li.r1 { background: #f0f0f0; } -li.r2 { background: #fafafa; } -li:hover { background: #ddd; } -li small:before { content: "("; } -li small:after { content: ")"; } -li small.search_info { display: none; } -a:link, a:visited { text-decoration: none; color: #05a; } -li.clicked { background: #05a; color: #ccc; } -li.clicked a:link, li.clicked a:visited { color: #eee; } -li.clicked a.toggle { opacity: 0.5; background-position: bottom right; } -li.collapsed.clicked a.toggle { background-position: top right; } -#search input { border: 1px solid #bbb; -moz-border-radius: 3px; -webkit-border-radius: 3px; } -#nav { margin-left: 10px; font-size: 0.9em; display: none; color: #aaa; } -#nav a:link, #nav a:visited { color: #358; } -#nav a:hover { background: transparent; color: #5af; } -.frames #nav span:after { content: ' | '; } -.frames #nav span:last-child:after { content: ''; } - -.frames #content h1 { margin-top: 0; } -.frames li { white-space: nowrap; cursor: normal; } -.frames li small { display: block; font-size: 0.8em; } -.frames li small:before { content: ""; } -.frames li small:after { content: ""; } -.frames li small.search_info { display: none; } -.frames #search { width: 170px; position: static; margin: 3px; margin-left: 10px; font-size: 0.9em; color: #888; padding-left: 0; padding-right: 24px; } -.frames #content.insearch #search { background-position: center right; } -.frames #search input { width: 110px; } -.frames #nav { display: block; } - -#full_list.insearch li { display: none; } -#full_list.insearch li.found { display: list-item; padding-left: 10px; } -#full_list.insearch li a.toggle { display: none; } -#full_list.insearch li small.search_info { display: block; } diff --git a/css/style.css b/css/style.css deleted file mode 100644 index 96307c56..00000000 --- a/css/style.css +++ /dev/null @@ -1,339 +0,0 @@ -body { - padding: 0 20px; - font-family: "Lucida Sans", "Lucida Grande", Verdana, Arial, sans-serif; - font-size: 13px; -} -body.frames { padding: 0 5px; } -h1 { font-size: 25px; margin: 1em 0 0.5em; padding-top: 4px; border-top: 1px dotted #d5d5d5; } -h1.noborder { border-top: 0px; margin-top: 0; padding-top: 4px; } -h1.title { margin-bottom: 10px; } -h1.alphaindex { margin-top: 0; font-size: 22px; } -h2 { - padding: 0; - padding-bottom: 3px; - border-bottom: 1px #aaa solid; - font-size: 1.4em; - margin: 1.8em 0 0.5em; -} -h2 small { font-weight: normal; font-size: 0.7em; display: block; float: right; } -.clear { clear: both; } -.inline { display: inline; } -.inline p:first-child { display: inline; } -.docstring h1, .docstring h2, .docstring h3, .docstring h4 { padding: 0; border: 0; border-bottom: 1px dotted #bbb; } -.docstring h1 { font-size: 1.2em; } -.docstring h2 { font-size: 1.1em; } -.docstring h3, .docstring h4 { font-size: 1em; border-bottom: 0; padding-top: 10px; } -.summary_desc .object_link, .docstring .object_link { font-family: monospace; } -.rdoc-term { padding-right: 25px; font-weight: bold; } -.rdoc-list p { margin: 0; padding: 0; margin-bottom: 4px; } - -/* style for */ -#filecontents table, .docstring table { border-collapse: collapse; } -#filecontents table th, #filecontents table td, -.docstring table th, .docstring table td { border: 1px solid #ccc; padding: 8px; padding-right: 17px; } -#filecontents table tr:nth-child(odd), -.docstring table tr:nth-child(odd) { background: #eee; } -#filecontents table tr:nth-child(even), -.docstring table tr:nth-child(even) { background: #fff; } -#filecontents table th, .docstring table th { background: #fff; } - -/* style for
- - - - - - - - - - - - -
Build Status - Build Status - Build status -
Code Quality - Code Quality - codebeat - Test Coverage -
Issue Stats - Pulse -
-

About

- -

ActiveModelSerializers brings convention over configuration to your JSON -generation.

- -

ActiveModelSerializers works through two components: -serializers and adapters.

- -

Serializers describe which attributes and relationships should be -serialized.

- -

Adapters describe how attributes and relationships should be -serialized.

- -

SerializableResource co-ordinates the resource, Adapter and Serializer to -produce the resource serialization. The serialization has the -#as_json, #to_json and -#serializable_hash methods used by the Rails JSON Renderer. -(SerializableResource actually delegates these methods to the adapter.)

- -

By default ActiveModelSerializers will use the Attributes -Adapter (no JSON root). But we strongly advise you to use -JsonApi Adapter, which follows 1.0 of the format specified -in jsonapi.org/format. Check how to -change the adapter in the sections below.

- -

0.10.x is not backward compatible with -0.9.x nor 0.8.x.

- -

0.10.x is based on the 0.8.0 code, but with a -more flexible architecture. We'd love your help. Learn how you can help here.

- -

It is generally safe and recommended to use the master branch.

- -

Installation

- -

Add this line to your application's Gemfile:

- -
gem 'active_model_serializers', '~> 0.10.0'
-
- -

And then execute:

- -
$ bundle
- -

Getting Started

- -

See Getting Started for the -nuts and bolts.

- -

More information is available in the Guides and High-level behavior.

- -

Getting Help

- -

If you find a bug, please report an Issue -and see our contributing guide.

- -

If you have a question, please post -to Stack Overflow.

- -

If you'd like to chat, we have a community slack.

- -

Thanks!

- -

Documentation

- - -

High-level behavior

- -

Choose an adapter from adapters:

- -
ActiveModelSerializers.config.adapter = :json_api # Default: `:attributes`
-
- -

Given a serializable -model:

- -
# either
-class SomeResource < ActiveRecord::Base
-  # columns: title, body
-end
-# or
-class SomeResource < ActiveModelSerializers::Model
-  attr_accessor :title, :body
-end
-
- -

And initialized as:

- -
resource = SomeResource.new(title: 'ActiveModelSerializers', body: 'Convention over configuration')
-
- -

Given a serializer for the serializable model:

- -
class SomeSerializer < ActiveModel::Serializer
-  attribute :title, key: :name
-  attributes :body
-end
-
- -

The model can be serialized as:

- -
options = {}
-serialization = ActiveModelSerializers::SerializableResource.new(resource, options)
-serialization.to_json
-serialization.as_json
-
- -

SerializableResource delegates to the adapter, which it builds as:

- -
adapter_options = {}
-adapter = ActiveModelSerializers::Adapter.create(serializer, adapter_options)
-adapter.to_json
-adapter.as_json
-adapter.serializable_hash
-
- -

The adapter formats the serializer's attributes and associations -(a.k.a. includes):

- -
serializer_options = {}
-serializer = SomeSerializer.new(resource, serializer_options)
-serializer.attributes
-serializer.associations
-
- -

See ARCHITECTURE.md for more -information.

- -

Contributing

- -

See CONTRIBUTING.md

- - - - - - \ No newline at end of file diff --git a/file_list.html b/file_list.html deleted file mode 100644 index 6bf67e5a..00000000 --- a/file_list.html +++ /dev/null @@ -1,60 +0,0 @@ - - - - - - - - - - - - - - - - - File List - - - - -
-

File List

- - - - -
- - diff --git a/frames.html b/frames.html deleted file mode 100644 index 87a4a6df..00000000 --- a/frames.html +++ /dev/null @@ -1,26 +0,0 @@ - - - - - - Documentation by YARD 0.8.7.6 - - - - diff --git a/index.html b/index.html deleted file mode 100644 index 1cfabbe3..00000000 --- a/index.html +++ /dev/null @@ -1,262 +0,0 @@ - - - - - - File: README - - — Documentation by YARD 0.8.7.6 - - - - - - - - - - - - - - - - - - - - - -
-

ActiveModelSerializers

- - - - - - - - - - - - - -
Build Status - Build Status - Build status -
Code Quality - Code Quality - codebeat - Test Coverage -
Issue Stats - Pulse -
-

About

- -

ActiveModelSerializers brings convention over configuration to your JSON -generation.

- -

ActiveModelSerializers works through two components: -serializers and adapters.

- -

Serializers describe which attributes and relationships should be -serialized.

- -

Adapters describe how attributes and relationships should be -serialized.

- -

SerializableResource co-ordinates the resource, Adapter and Serializer to -produce the resource serialization. The serialization has the -#as_json, #to_json and -#serializable_hash methods used by the Rails JSON Renderer. -(SerializableResource actually delegates these methods to the adapter.)

- -

By default ActiveModelSerializers will use the Attributes -Adapter (no JSON root). But we strongly advise you to use -JsonApi Adapter, which follows 1.0 of the format specified -in jsonapi.org/format. Check how to -change the adapter in the sections below.

- -

0.10.x is not backward compatible with -0.9.x nor 0.8.x.

- -

0.10.x is based on the 0.8.0 code, but with a -more flexible architecture. We'd love your help. Learn how you can help here.

- -

It is generally safe and recommended to use the master branch.

- -

Installation

- -

Add this line to your application's Gemfile:

- -
gem 'active_model_serializers', '~> 0.10.0'
-
- -

And then execute:

- -
$ bundle
- -

Getting Started

- -

See Getting Started for the -nuts and bolts.

- -

More information is available in the Guides and High-level behavior.

- -

Getting Help

- -

If you find a bug, please report an Issue -and see our contributing guide.

- -

If you have a question, please post -to Stack Overflow.

- -

If you'd like to chat, we have a community slack.

- -

Thanks!

- -

Documentation

- - -

High-level behavior

- -

Choose an adapter from adapters:

- -
ActiveModelSerializers.config.adapter = :json_api # Default: `:attributes`
-
- -

Given a serializable -model:

- -
# either
-class SomeResource < ActiveRecord::Base
-  # columns: title, body
-end
-# or
-class SomeResource < ActiveModelSerializers::Model
-  attr_accessor :title, :body
-end
-
- -

And initialized as:

- -
resource = SomeResource.new(title: 'ActiveModelSerializers', body: 'Convention over configuration')
-
- -

Given a serializer for the serializable model:

- -
class SomeSerializer < ActiveModel::Serializer
-  attribute :title, key: :name
-  attributes :body
-end
-
- -

The model can be serialized as:

- -
options = {}
-serialization = ActiveModelSerializers::SerializableResource.new(resource, options)
-serialization.to_json
-serialization.as_json
-
- -

SerializableResource delegates to the adapter, which it builds as:

- -
adapter_options = {}
-adapter = ActiveModelSerializers::Adapter.create(serializer, adapter_options)
-adapter.to_json
-adapter.as_json
-adapter.serializable_hash
-
- -

The adapter formats the serializer's attributes and associations -(a.k.a. includes):

- -
serializer_options = {}
-serializer = SomeSerializer.new(resource, serializer_options)
-serializer.attributes
-serializer.associations
-
- -

See ARCHITECTURE.md for more -information.

- -

Contributing

- -

See CONTRIBUTING.md

-
- - - - - \ No newline at end of file diff --git a/js/app.js b/js/app.js deleted file mode 100644 index d933ebcf..00000000 --- a/js/app.js +++ /dev/null @@ -1,219 +0,0 @@ -function createSourceLinks() { - $('.method_details_list .source_code'). - before("[View source]"); - $('.toggleSource').toggle(function() { - $(this).parent().nextAll('.source_code').slideDown(100); - $(this).text("Hide source"); - }, - function() { - $(this).parent().nextAll('.source_code').slideUp(100); - $(this).text("View source"); - }); -} - -function createDefineLinks() { - var tHeight = 0; - $('.defines').after(" more..."); - $('.toggleDefines').toggle(function() { - tHeight = $(this).parent().prev().height(); - $(this).prev().show(); - $(this).parent().prev().height($(this).parent().height()); - $(this).text("(less)"); - }, - function() { - $(this).prev().hide(); - $(this).parent().prev().height(tHeight); - $(this).text("more..."); - }); -} - -function createFullTreeLinks() { - var tHeight = 0; - $('.inheritanceTree').toggle(function() { - tHeight = $(this).parent().prev().height(); - $(this).parent().toggleClass('showAll'); - $(this).text("(hide)"); - $(this).parent().prev().height($(this).parent().height()); - }, - function() { - $(this).parent().toggleClass('showAll'); - $(this).parent().prev().height(tHeight); - $(this).text("show all"); - }); -} - -function fixBoxInfoHeights() { - $('dl.box dd.r1, dl.box dd.r2').each(function() { - $(this).prev().height($(this).height()); - }); -} - -function searchFrameLinks() { - $('.full_list_link').click(function() { - toggleSearchFrame(this, $(this).attr('href')); - return false; - }); -} - -function toggleSearchFrame(id, link) { - var frame = $('#search_frame'); - $('#search a').removeClass('active').addClass('inactive'); - if (frame.attr('src') == link && frame.css('display') != "none") { - frame.slideUp(100); - $('#search a').removeClass('active inactive'); - } - else { - $(id).addClass('active').removeClass('inactive'); - frame.attr('src', link).slideDown(100); - } -} - -function linkSummaries() { - $('.summary_signature').click(function() { - document.location = $(this).find('a').attr('href'); - }); -} - -function framesInit() { - if (hasFrames) { - document.body.className = 'frames'; - $('#menu .noframes a').attr('href', document.location); - try { - window.top.document.title = $('html head title').text(); - } catch(error) { - // some browsers will not allow this when serving from file:// - // but we don't want to stop the world. - } - } - else { - $('#menu .noframes a').text('frames').attr('href', framesUrl); - } -} - -function keyboardShortcuts() { - if (window.top.frames.main) return; - $(document).keypress(function(evt) { - if (evt.altKey || evt.ctrlKey || evt.metaKey || evt.shiftKey) return; - if (typeof evt.target !== "undefined" && - (evt.target.nodeName == "INPUT" || - evt.target.nodeName == "TEXTAREA")) return; - switch (evt.charCode) { - case 67: case 99: $('#class_list_link').click(); break; // 'c' - case 77: case 109: $('#method_list_link').click(); break; // 'm' - case 70: case 102: $('#file_list_link').click(); break; // 'f' - default: break; - } - }); -} - -function summaryToggle() { - $('.summary_toggle').click(function() { - if (localStorage) { - localStorage.summaryCollapsed = $(this).text(); - } - $('.summary_toggle').each(function() { - $(this).text($(this).text() == "collapse" ? "expand" : "collapse"); - var next = $(this).parent().parent().nextAll('ul.summary').first(); - if (next.hasClass('compact')) { - next.toggle(); - next.nextAll('ul.summary').first().toggle(); - } - else if (next.hasClass('summary')) { - var list = $('